From 365a25ff7f90cd9768fc25131720f8407d17a341 Mon Sep 17 00:00:00 2001 From: binh-dam-ibigroup <56846598+binh-dam-ibigroup@users.noreply.github.com> Date: Thu, 14 Nov 2024 16:05:07 -0500 Subject: [PATCH] fix(MobilityProfile): Correctly assign "Some" profile if restricted mobility and no devices. --- .../middleware/models/MobilityProfile.java | 7 +++--- .../models/MobilityProfileTest.java | 25 +++++++++++-------- 2 files changed, 19 insertions(+), 13 deletions(-) diff --git a/src/main/java/org/opentripplanner/middleware/models/MobilityProfile.java b/src/main/java/org/opentripplanner/middleware/models/MobilityProfile.java index b8310e5b7..854691a88 100644 --- a/src/main/java/org/opentripplanner/middleware/models/MobilityProfile.java +++ b/src/main/java/org/opentripplanner/middleware/models/MobilityProfile.java @@ -85,10 +85,11 @@ public void updateMobilityMode() { if (mobilityDevices.contains("manual wheelchair")) { mModeTemp = "WChairM"; } + } - if ("None".equals(mModeTemp) && isMobilityLimited) { - mModeTemp = "Some"; - } + // Adjust mobility limitations if the person has other impairments that don't require mobility devices. + if ("None".equals(mModeTemp) && isMobilityLimited) { + mModeTemp = "Some"; } if (MobilityProfile.VisionLimitation.LOW_VISION == visionLimitation) { diff --git a/src/test/java/org/opentripplanner/middleware/models/MobilityProfileTest.java b/src/test/java/org/opentripplanner/middleware/models/MobilityProfileTest.java index ea9c095ee..2cb951126 100644 --- a/src/test/java/org/opentripplanner/middleware/models/MobilityProfileTest.java +++ b/src/test/java/org/opentripplanner/middleware/models/MobilityProfileTest.java @@ -12,7 +12,7 @@ /** * This class contains tests of selected scenarios in {@link MobilityProfile}. */ -public class MobilityProfileTest { +class MobilityProfileTest { // The mobility modes tested are tightly coupled with algorithms in the // Georgia Tech Mobility Profile Configuration / Logical Flow document, as // implemented in the MobilityProfile#updateMobilityMode() method. Changes @@ -20,21 +20,26 @@ public class MobilityProfileTest { private static Stream provideModes() { return Stream.of( - Arguments.of(Set.of("service animal", "crutches"), "Device"), - Arguments.of(Set.of("service animal", "electric wheelchair"), "WChairE"), - Arguments.of(Set.of("service animal", "electric wheelchair", "white cane"), "WChairE-Blind"), - Arguments.of(Set.of("manual wheelchair", "electric wheelchair", "white cane"), "WChairM-Blind"), - Arguments.of(Collections.EMPTY_SET, "None"), - Arguments.of(Set.of("cardboard transmogrifier"), "None"), // Unknown/invalid device - Arguments.of(Set.of("cane", "none", "service animal"), "None") // Devices include "none" poison pill + Arguments.of(Set.of("service animal", "crutches"), false, "Device"), + Arguments.of(Set.of("service animal", "crutches"), true, "Device"), + Arguments.of(Set.of("service animal", "electric wheelchair"), false, "WChairE"), + Arguments.of(Set.of("service animal", "electric wheelchair", "white cane"), false, "WChairE-Blind"), + Arguments.of(Set.of("manual wheelchair", "electric wheelchair", "white cane"), false, "WChairM-Blind"), + Arguments.of(Collections.EMPTY_SET, false, "None"), + Arguments.of(Collections.EMPTY_SET, true, "Some"), + Arguments.of(Set.of("cardboard transmogrifier"), false, "None"), // Unknown/invalid device + Arguments.of(Set.of("cane", "none", "service animal"), false, "None"), // Devices include "none" poison pill + Arguments.of(Set.of("none"), false, "None"), // Devices include "none" poison pill + Arguments.of(Set.of("none"), true, "Some") // Devices include "none" poison pill ); } @ParameterizedTest @MethodSource("provideModes") - public void testModes(Set devices, String mode) { + void testModes(Set devices, boolean isMobilityLimited, String mode) { var prof = new MobilityProfile(); prof.mobilityDevices = devices; + prof.isMobilityLimited = isMobilityLimited; prof.updateMobilityMode(); Assertions.assertEquals(mode, prof.mobilityMode); } @@ -50,7 +55,7 @@ private static Stream provideModesVision() { @ParameterizedTest @MethodSource("provideModesVision") - public void testModesVision(MobilityProfile.VisionLimitation limitation, Set devices, String mode) { + void testModesVision(MobilityProfile.VisionLimitation limitation, Set devices, String mode) { var prof = new MobilityProfile(); prof.mobilityDevices = devices; prof.visionLimitation = limitation;