diff --git a/.github/workflows/ant.yml b/.github/workflows/ant.yml
index 69765ea1..d2fcbee3 100644
--- a/.github/workflows/ant.yml
+++ b/.github/workflows/ant.yml
@@ -16,12 +16,12 @@ jobs:
call-workflow:
strategy:
matrix:
- josm-revision: ["", "r18877"]
- uses: JOSM/JOSMPluginAction/.github/workflows/ant.yml@v2
+ josm-revision: ["", "r19067"]
+ uses: JOSM/JOSMPluginAction/.github/workflows/ant.yml@v3
with:
java-version: 17
josm-revision: ${{ matrix.josm-revision }}
plugin-jar-name: 'mapwithai'
- perform-revision-tagging: ${{ matrix.josm-revision == 'r18877' && github.repository == 'JOSM/MapWithAI' && github.ref_type == 'branch' && github.ref_name == 'master' && github.event_name != 'schedule' && github.event_name != 'pull_request' }}
+ perform-revision-tagging: ${{ matrix.josm-revision == 'r19067' && github.repository == 'JOSM/MapWithAI' && github.ref_type == 'branch' && github.ref_name == 'master' && github.event_name != 'schedule' && github.event_name != 'pull_request' }}
secrets: inherit
diff --git a/.github/workflows/reports.yaml b/.github/workflows/reports.yaml
index 43794f4f..007304f0 100644
--- a/.github/workflows/reports.yaml
+++ b/.github/workflows/reports.yaml
@@ -10,4 +10,4 @@ permissions:
jobs:
call-workflow:
- uses: JOSM/JOSMPluginAction/.github/workflows/reports.yaml@v2
+ uses: JOSM/JOSMPluginAction/.github/workflows/reports.yaml@v3
diff --git a/gradle.properties b/gradle.properties
index 28d74150..5c5f4494 100644
--- a/gradle.properties
+++ b/gradle.properties
@@ -1,9 +1,9 @@
# The minimum JOSM version this plugin is compatible with (can be any numeric version
-plugin.main.version = 18877
+plugin.main.version = 19067
# The JOSM version this plugin is currently compiled against
# Please make sure this version is available at https://josm.openstreetmap.de/download
# The special values "latest" and "tested" are also possible here, but not recommended.
-plugin.compile.version = 18877
+plugin.compile.version = 19067
plugin.canloadatruntime = true
plugin.author = Taylor Smock
plugin.class = org.openstreetmap.josm.plugins.mapwithai.MapWithAIPlugin
diff --git a/pom.xml b/pom.xml
new file mode 100644
index 00000000..a836507a
--- /dev/null
+++ b/pom.xml
@@ -0,0 +1,193 @@
+
+ 4.0.0
+ org.openstreetmap.josm.plugins
+ MapWithAI
+ SNAPSHOT
+
+ 1.49.a
+ 7.5.0
+ 0.8.12
+ 10.18.1
+ 4.8.6
+
+
+
+ JOSM-releases
+ https://josm.openstreetmap.de/nexus/content/repositories/releases/
+
+
+ JOSM-snapshots
+ https://josm.openstreetmap.de/nexus/content/repositories/snapshots/
+
+
+
+
+
+ org.junit
+ junit-bom
+ 5.11.1
+ pom
+ import
+
+
+
+
+
+ org.openstreetmap.josm
+ josm
+ SNAPSHOT
+ provided
+
+
+ org.openstreetmap.josm.plugins
+ pmtiles
+ SNAPSHOT
+ provided
+
+
+ org.openstreetmap.josm.plugins
+ utilsplugin2
+ SNAPSHOT
+ provided
+
+
+ org.openstreetmap.josm
+ josm-unittest
+ SNAPSHOT
+ test
+
+
+ org.wiremock
+ wiremock
+ 3.9.1
+ test
+
+
+ org.junit.jupiter
+ junit-jupiter-api
+ test
+
+
+ org.junit.jupiter
+ junit-jupiter-params
+ test
+
+
+ junit
+ junit
+ 4.13.2
+ test
+
+
+ org.awaitility
+ awaitility
+ 4.2.2
+ test
+
+
+ nl.jqno.equalsverifier
+ equalsverifier
+ 3.17
+ test
+
+
+ org.jmockit
+ jmockit
+ 1.49.a
+ test
+
+
+ jakarta.json
+ jakarta.json-api
+ 2.1.3
+ provided
+
+
+
+ src/test/unit
+
+
+ org.apache.maven.plugins
+ maven-compiler-plugin
+ 3.13.0
+
+ 17
+
+
+
+ com.diffplug.spotless
+ spotless-maven-plugin
+ 2.43.0
+
+
+
+ 4.21
+ ${project.basedir}/../00_core_tools/eclipse/formatter.xml
+
+
+
+ // License: GPL. For details, see LICENSE file.
+
+
+ src/main/java/**/*.java
+ src/test/unit/**/*.java
+ src/test/integration/**/*.java
+
+
+
+
+
+
+ check
+
+
+
+
+
+ org.apache.maven.plugins
+ maven-enforcer-plugin
+ 3.5.0
+
+
+ enforce-maven
+
+ enforce
+
+
+
+
+
+
+ 3.6.3
+
+
+
+
+
+
+ maven-surefire-plugin
+ 3.2.5
+
+ 1
+ -javaagent:"${settings.localRepository}"/org/jmockit/jmockit/${jmockit.version}/jmockit-${jmockit.version}.jar
+
+
+ file.encoding = UTF-8
+ java.locale.providers = SPI,CLDR
+ junit.jupiter.extensions.autodetection.enabled = true
+ junit.jupiter.execution.parallel.enabled = true
+
+
+
+ src/test/build/config/josm.home
+ src/test/resources
+ true
+ Monocle
+ Headless
+ sw
+
+
+
+
+
+
diff --git a/src/main/java/org/openstreetmap/josm/plugins/mapwithai/data/mapwithai/MapWithAILayerInfo.java b/src/main/java/org/openstreetmap/josm/plugins/mapwithai/data/mapwithai/MapWithAILayerInfo.java
index b5d9bd7c..85a54344 100644
--- a/src/main/java/org/openstreetmap/josm/plugins/mapwithai/data/mapwithai/MapWithAILayerInfo.java
+++ b/src/main/java/org/openstreetmap/josm/plugins/mapwithai/data/mapwithai/MapWithAILayerInfo.java
@@ -359,8 +359,6 @@ private void updateEsriLayers(@Nonnull final Collection layers) {
Logging.error(e);
}
}
- } else {
- esriInfo.add(layer);
}
}
layers.addAll(esriInfo);
diff --git a/src/main/java/org/openstreetmap/josm/plugins/mapwithai/data/validation/tests/StreetAddressTest.java b/src/main/java/org/openstreetmap/josm/plugins/mapwithai/data/validation/tests/StreetAddressTest.java
index b547839d..3a7c3cf1 100644
--- a/src/main/java/org/openstreetmap/josm/plugins/mapwithai/data/validation/tests/StreetAddressTest.java
+++ b/src/main/java/org/openstreetmap/josm/plugins/mapwithai/data/validation/tests/StreetAddressTest.java
@@ -44,8 +44,8 @@ public class StreetAddressTest extends Test {
public static final double BBOX_EXPANSION = 0.002;
private static final String ADDR_STREET = "addr:street";
private final Set namePrimitiveMap = new HashSet<>();
- private final Map> nameMap = new HashMap<>();
- private final Map> primitiveCellMap = new HashMap<>();
+ private final Map> nameMap = new HashMap<>();
+ private final Map> primitiveCellMap = new HashMap<>();
/**
* Classified highways. This uses a {@link Set} instead of a {@link List} since
* the MapWithAI code doesn't care about order.
@@ -146,7 +146,8 @@ private void realVisit(OsmPrimitive primitive) {
final var n1 = nodes.get(i);
final var n2 = nodes.get(i + 1);
for (Point2D cell : ValUtil.getSegmentCells(n1, n2, gridDetail)) {
- this.nameMap.computeIfAbsent(cell, k -> new HashSet<>()).addAll(names);
+ this.nameMap.computeIfAbsent(new Point(cell.getX(), cell.getY()), k -> new HashSet<>())
+ .addAll(names);
}
}
} else if (hasStreetAddressTags(primitive) && !primitive.isOutsideDownloadArea()) {
@@ -159,7 +160,7 @@ private void realVisit(OsmPrimitive primitive) {
if (en != null) {
long x = (long) Math.floor(en.getX() * gridDetail);
long y = (long) Math.floor(en.getY() * gridDetail);
- final var point = new Point2D.Double(x, y);
+ final var point = new Point(x, y);
primitiveCellMap.computeIfAbsent(point, p -> new ArrayList<>()).add(primitive);
}
}
@@ -174,7 +175,7 @@ private static Collection getWayNames(IPrimitive way) {
.filter(s -> !s.isEmpty()).collect(Collectors.toSet());
}
- private Collection getSurroundingHighwayNames(Point2D point2D) {
+ private Collection getSurroundingHighwayNames(Point point2D) {
if (this.nameMap.isEmpty()) {
return Collections.emptySet();
}
@@ -183,8 +184,9 @@ private Collection getSurroundingHighwayNames(Point2D point2D) {
while (surroundingWays.isEmpty()) {
for (int x = -surrounding; x <= surrounding; x++) {
for (int y = -surrounding; y <= surrounding; y++) {
- final var key = new Point2D.Double((long) Math.floor(point2D.getX() + x),
- (long) Math.floor(point2D.getY() + y));
+ final var xPoint = (long) Math.floor(point2D.x() + x);
+ final var yPoint = (long) Math.floor(point2D.y() + y);
+ final var key = new Point(xPoint, yPoint);
if (this.nameMap.containsKey(key)) {
surroundingWays.addAll(this.nameMap.get(key));
}
@@ -303,4 +305,20 @@ public static BBox expandBBox(BBox bbox, double degree) {
bbox.add(bbox.getTopLeftLon() - degree, bbox.getTopLeftLat() + degree);
return bbox;
}
-}
+
+ private record Point(double x, double y) implements Comparable {
+
+ @Override
+ public int compareTo(Point other) {
+ if (other.x == this.x && other.y == this.y) {
+ return 0;
+ }
+ if (other.x < this.x) {
+ return -1;
+ }
+ if (other.x > this.x) {
+ return 1;
+ }
+ return Double.compare(other.y, this.y);
+ }
+}}
diff --git a/src/test/data b/src/test/data
new file mode 120000
index 00000000..fc478085
--- /dev/null
+++ b/src/test/data
@@ -0,0 +1 @@
+resources
\ No newline at end of file
diff --git a/src/test/resources/wiremock/__files/MapWithAIStyle.zip b/src/test/resources/__files/MapWithAIStyle.zip
similarity index 100%
rename from src/test/resources/wiremock/__files/MapWithAIStyle.zip
rename to src/test/resources/__files/MapWithAIStyle.zip
diff --git a/src/test/resources/wiremock/__files/josmfile?page=Styles/MapWithAI&zip=1 b/src/test/resources/__files/josmfile?page=Styles/MapWithAI&zip=1
similarity index 100%
rename from src/test/resources/wiremock/__files/josmfile?page=Styles/MapWithAI&zip=1
rename to src/test/resources/__files/josmfile?page=Styles/MapWithAI&zip=1
diff --git a/src/test/resources/wiremock/mappings/06_nodes-5f086efd-b8fa-4340-b368-cd4fa7626e0b.json b/src/test/resources/mappings/06_nodes-5f086efd-b8fa-4340-b368-cd4fa7626e0b.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/06_nodes-5f086efd-b8fa-4340-b368-cd4fa7626e0b.json
rename to src/test/resources/mappings/06_nodes-5f086efd-b8fa-4340-b368-cd4fa7626e0b.json
diff --git a/src/test/resources/wiremock/mappings/06_nodes-7938c30e-bd58-4c8c-a716-49e434123ccb.json b/src/test/resources/mappings/06_nodes-7938c30e-bd58-4c8c-a716-49e434123ccb.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/06_nodes-7938c30e-bd58-4c8c-a716-49e434123ccb.json
rename to src/test/resources/mappings/06_nodes-7938c30e-bd58-4c8c-a716-49e434123ccb.json
diff --git a/src/test/resources/wiremock/mappings/06_nodes-98af8a28-e882-4d58-a828-f149ef8b3913.json b/src/test/resources/mappings/06_nodes-98af8a28-e882-4d58-a828-f149ef8b3913.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/06_nodes-98af8a28-e882-4d58-a828-f149ef8b3913.json
rename to src/test/resources/mappings/06_nodes-98af8a28-e882-4d58-a828-f149ef8b3913.json
diff --git a/src/test/resources/wiremock/mappings/06_nodes-aa8912c8-d2fc-4c2d-bf5e-f0192dad2bb4.json b/src/test/resources/mappings/06_nodes-aa8912c8-d2fc-4c2d-bf5e-f0192dad2bb4.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/06_nodes-aa8912c8-d2fc-4c2d-bf5e-f0192dad2bb4.json
rename to src/test/resources/mappings/06_nodes-aa8912c8-d2fc-4c2d-bf5e-f0192dad2bb4.json
diff --git a/src/test/resources/wiremock/mappings/capabilities-cf884424-9817-4f92-a3af-6b5aa2bc4b0e.json b/src/test/resources/mappings/capabilities-cf884424-9817-4f92-a3af-6b5aa2bc4b0e.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/capabilities-cf884424-9817-4f92-a3af-6b5aa2bc4b0e.json
rename to src/test/resources/mappings/capabilities-cf884424-9817-4f92-a3af-6b5aa2bc4b0e.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_abilene_tx_buildings_featureserver-cf2fc003-e869-4bff-9c52-16e73cf89b9d.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_abilene_tx_buildings_featureserver-cf2fc003-e869-4bff-9c52-16e73cf89b9d.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_abilene_tx_buildings_featureserver-cf2fc003-e869-4bff-9c52-16e73cf89b9d.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_abilene_tx_buildings_featureserver-cf2fc003-e869-4bff-9c52-16e73cf89b9d.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_alexandria_va_addresses_featureserver-ffce8d3a-c21a-410b-9303-2b59875b76aa.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_alexandria_va_addresses_featureserver-ffce8d3a-c21a-410b-9303-2b59875b76aa.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_alexandria_va_addresses_featureserver-ffce8d3a-c21a-410b-9303-2b59875b76aa.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_alexandria_va_addresses_featureserver-ffce8d3a-c21a-410b-9303-2b59875b76aa.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_alexandria_va_addresses_featureserver_0-ee34e070-0bf4-4a36-bfe5-4833a8f25ae5.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_alexandria_va_addresses_featureserver_0-ee34e070-0bf4-4a36-bfe5-4833a8f25ae5.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_alexandria_va_addresses_featureserver_0-ee34e070-0bf4-4a36-bfe5-4833a8f25ae5.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_alexandria_va_addresses_featureserver_0-ee34e070-0bf4-4a36-bfe5-4833a8f25ae5.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_baton_rouge_la_buildings_featureserver-dd6fd63f-5bf7-44e1-96cb-3accb0d9e652.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_baton_rouge_la_buildings_featureserver-dd6fd63f-5bf7-44e1-96cb-3accb0d9e652.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_baton_rouge_la_buildings_featureserver-dd6fd63f-5bf7-44e1-96cb-3accb0d9e652.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_baton_rouge_la_buildings_featureserver-dd6fd63f-5bf7-44e1-96cb-3accb0d9e652.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_boston_ma_addresses_featureserver-1878a845-e581-4519-9568-57e3c4ca5681.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_boston_ma_addresses_featureserver-1878a845-e581-4519-9568-57e3c4ca5681.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_boston_ma_addresses_featureserver-1878a845-e581-4519-9568-57e3c4ca5681.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_boston_ma_addresses_featureserver-1878a845-e581-4519-9568-57e3c4ca5681.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_flagstaff_az_addresses_featureserver-f5b30af0-0177-459b-ac7a-b4fc0be7d99a.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_flagstaff_az_addresses_featureserver-f5b30af0-0177-459b-ac7a-b4fc0be7d99a.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_flagstaff_az_addresses_featureserver-f5b30af0-0177-459b-ac7a-b4fc0be7d99a.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_flagstaff_az_addresses_featureserver-f5b30af0-0177-459b-ac7a-b4fc0be7d99a.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_flagstaff_az_addresses_featureserver_0-d0e9831e-6eff-4f7e-83ee-f09bad38c40d.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_flagstaff_az_addresses_featureserver_0-d0e9831e-6eff-4f7e-83ee-f09bad38c40d.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_flagstaff_az_addresses_featureserver_0-d0e9831e-6eff-4f7e-83ee-f09bad38c40d.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_flagstaff_az_addresses_featureserver_0-d0e9831e-6eff-4f7e-83ee-f09bad38c40d.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_fort_collins_co_buildings_featureserver-5b042812-8b74-43cc-8f3c-5455209e6174.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_fort_collins_co_buildings_featureserver-5b042812-8b74-43cc-8f3c-5455209e6174.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_fort_collins_co_buildings_featureserver-5b042812-8b74-43cc-8f3c-5455209e6174.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_fort_collins_co_buildings_featureserver-5b042812-8b74-43cc-8f3c-5455209e6174.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklin_county_oh_buildings_featureserver-9f5608b0-7f9b-4744-9bfa-aca77b68a338.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklin_county_oh_buildings_featureserver-9f5608b0-7f9b-4744-9bfa-aca77b68a338.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklin_county_oh_buildings_featureserver-9f5608b0-7f9b-4744-9bfa-aca77b68a338.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklin_county_oh_buildings_featureserver-9f5608b0-7f9b-4744-9bfa-aca77b68a338.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklincounty_buildings_featureserver-4a594e6d-4b81-42ad-b547-39005f2a5f62.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklincounty_buildings_featureserver-4a594e6d-4b81-42ad-b547-39005f2a5f62.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklincounty_buildings_featureserver-4a594e6d-4b81-42ad-b547-39005f2a5f62.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklincounty_buildings_featureserver-4a594e6d-4b81-42ad-b547-39005f2a5f62.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklincounty_buildings_featureserver_0-8cd10b04-891d-4d27-9282-82e7349f5bd3.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklincounty_buildings_featureserver_0-8cd10b04-891d-4d27-9282-82e7349f5bd3.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklincounty_buildings_featureserver_0-8cd10b04-891d-4d27-9282-82e7349f5bd3.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_franklincounty_buildings_featureserver_0-8cd10b04-891d-4d27-9282-82e7349f5bd3.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_indianapolis_in_buildings_featureserver-0839729e-481d-474b-b6c4-186632418ff8.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_indianapolis_in_buildings_featureserver-0839729e-481d-474b-b6c4-186632418ff8.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_indianapolis_in_buildings_featureserver-0839729e-481d-474b-b6c4-186632418ff8.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_indianapolis_in_buildings_featureserver-0839729e-481d-474b-b6c4-186632418ff8.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_johns_creek_ga_addresses_featureserver-1af1902a-7f3e-406c-baae-c87beb5f51b2.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_johns_creek_ga_addresses_featureserver-1af1902a-7f3e-406c-baae-c87beb5f51b2.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_johns_creek_ga_addresses_featureserver-1af1902a-7f3e-406c-baae-c87beb5f51b2.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_johns_creek_ga_addresses_featureserver-1af1902a-7f3e-406c-baae-c87beb5f51b2.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_johns_creek_ga_buildings_featureserver-1f76a677-dad5-47c2-86f9-a6215bd47f09.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_johns_creek_ga_buildings_featureserver-1f76a677-dad5-47c2-86f9-a6215bd47f09.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_johns_creek_ga_buildings_featureserver-1f76a677-dad5-47c2-86f9-a6215bd47f09.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_johns_creek_ga_buildings_featureserver-1f76a677-dad5-47c2-86f9-a6215bd47f09.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_madison_county_ky_addresses_featureserver-66ef9aca-060f-4595-ba9d-426efca7992a.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_madison_county_ky_addresses_featureserver-66ef9aca-060f-4595-ba9d-426efca7992a.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_madison_county_ky_addresses_featureserver-66ef9aca-060f-4595-ba9d-426efca7992a.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_madison_county_ky_addresses_featureserver-66ef9aca-060f-4595-ba9d-426efca7992a.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_featureserver-757edf0f-0dc4-4b42-869e-1bc2cf3ecf31.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_featureserver-757edf0f-0dc4-4b42-869e-1bc2cf3ecf31.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_featureserver-757edf0f-0dc4-4b42-869e-1bc2cf3ecf31.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_featureserver-757edf0f-0dc4-4b42-869e-1bc2cf3ecf31.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_featureserver_0-e759c7d0-92ff-4db5-9bd8-25c500797126.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_featureserver_0-e759c7d0-92ff-4db5-9bd8-25c500797126.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_featureserver_0-e759c7d0-92ff-4db5-9bd8-25c500797126.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_featureserver_0-e759c7d0-92ff-4db5-9bd8-25c500797126.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_v2_featureserver-e0115f5a-2f2f-4c3c-bd23-97d8b183e7f7.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_v2_featureserver-e0115f5a-2f2f-4c3c-bd23-97d8b183e7f7.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_v2_featureserver-e0115f5a-2f2f-4c3c-bd23-97d8b183e7f7.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_orange_county_ca_buildings_v2_featureserver-e0115f5a-2f2f-4c3c-bd23-97d8b183e7f7.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_pottawattamie_county_ia_buildings_featureserver-146e68bf-e36f-4d1a-9670-5cdbe2c3f636.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_pottawattamie_county_ia_buildings_featureserver-146e68bf-e36f-4d1a-9670-5cdbe2c3f636.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_pottawattamie_county_ia_buildings_featureserver-146e68bf-e36f-4d1a-9670-5cdbe2c3f636.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_pottawattamie_county_ia_buildings_featureserver-146e68bf-e36f-4d1a-9670-5cdbe2c3f636.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_richland_county_nd_addresses_featureserver-6b8d2ee4-b32f-4e81-80d1-bdf6bf8bba3f.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_richland_county_nd_addresses_featureserver-6b8d2ee4-b32f-4e81-80d1-bdf6bf8bba3f.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_richland_county_nd_addresses_featureserver-6b8d2ee4-b32f-4e81-80d1-bdf6bf8bba3f.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_richland_county_nd_addresses_featureserver-6b8d2ee4-b32f-4e81-80d1-bdf6bf8bba3f.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_featureserver-1b8f292c-d3b0-4281-ad07-680b02579e6b.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_featureserver-1b8f292c-d3b0-4281-ad07-680b02579e6b.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_featureserver-1b8f292c-d3b0-4281-ad07-680b02579e6b.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_featureserver-1b8f292c-d3b0-4281-ad07-680b02579e6b.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_featureserver_0-9bba8228-60ea-4b25-b140-ea7b4aeb79ab.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_featureserver_0-9bba8228-60ea-4b25-b140-ea7b4aeb79ab.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_featureserver_0-9bba8228-60ea-4b25-b140-ea7b4aeb79ab.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_featureserver_0-9bba8228-60ea-4b25-b140-ea7b4aeb79ab.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_v2_featureserver-646c0289-b022-4f04-a4e2-b402a256f18d.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_v2_featureserver-646c0289-b022-4f04-a4e2-b402a256f18d.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_v2_featureserver-646c0289-b022-4f04-a4e2-b402a256f18d.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_riverside_ca_buildings_v2_featureserver-646c0289-b022-4f04-a4e2-b402a256f18d.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sandiego_county_ca_addresses_featureserver-35444ef3-ef5b-4ba3-b2e6-8eaa2b18bb4c.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sandiego_county_ca_addresses_featureserver-35444ef3-ef5b-4ba3-b2e6-8eaa2b18bb4c.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sandiego_county_ca_addresses_featureserver-35444ef3-ef5b-4ba3-b2e6-8eaa2b18bb4c.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sandiego_county_ca_addresses_featureserver-35444ef3-ef5b-4ba3-b2e6-8eaa2b18bb4c.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sangis_buildings_featureserver-7100a55a-11f9-4a63-ab7e-27e463171e03.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sangis_buildings_featureserver-7100a55a-11f9-4a63-ab7e-27e463171e03.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sangis_buildings_featureserver-7100a55a-11f9-4a63-ab7e-27e463171e03.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sangis_buildings_featureserver-7100a55a-11f9-4a63-ab7e-27e463171e03.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_addresses_featureserver-7950efe2-fcb1-4457-9b3a-fd281eb49684.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_addresses_featureserver-7950efe2-fcb1-4457-9b3a-fd281eb49684.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_addresses_featureserver-7950efe2-fcb1-4457-9b3a-fd281eb49684.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_addresses_featureserver-7950efe2-fcb1-4457-9b3a-fd281eb49684.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_addresses_featureserver_1-89bb3fed-c485-401c-a9b9-9c5b367f81a0.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_addresses_featureserver_1-89bb3fed-c485-401c-a9b9-9c5b367f81a0.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_addresses_featureserver_1-89bb3fed-c485-401c-a9b9-9c5b367f81a0.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_addresses_featureserver_1-89bb3fed-c485-401c-a9b9-9c5b367f81a0.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_buildings_featureserver-1ab90e03-6781-4f0b-97c0-9e66b728c81c.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_buildings_featureserver-1ab90e03-6781-4f0b-97c0-9e66b728c81c.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_buildings_featureserver-1ab90e03-6781-4f0b-97c0-9e66b728c81c.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_buildings_featureserver-1ab90e03-6781-4f0b-97c0-9e66b728c81c.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_buildings_featureserver_1-1edea050-3368-40f5-80ae-099dba138e0d.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_buildings_featureserver_1-1edea050-3368-40f5-80ae-099dba138e0d.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_buildings_featureserver_1-1edea050-3368-40f5-80ae-099dba138e0d.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sarpy_county_ne_buildings_featureserver_1-1edea050-3368-40f5-80ae-099dba138e0d.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sioux_falls_sd_addresses_featureserver-c933f432-3e62-4fec-be6e-4f95894bd3b9.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sioux_falls_sd_addresses_featureserver-c933f432-3e62-4fec-be6e-4f95894bd3b9.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sioux_falls_sd_addresses_featureserver-c933f432-3e62-4fec-be6e-4f95894bd3b9.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sioux_falls_sd_addresses_featureserver-c933f432-3e62-4fec-be6e-4f95894bd3b9.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sioux_falls_sd_buildings_featureserver-3f1883b1-14dc-402f-bbbe-8d5f346ffcd6.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sioux_falls_sd_buildings_featureserver-3f1883b1-14dc-402f-bbbe-8d5f346ffcd6.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_sioux_falls_sd_buildings_featureserver-3f1883b1-14dc-402f-bbbe-8d5f346ffcd6.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_sioux_falls_sd_buildings_featureserver-3f1883b1-14dc-402f-bbbe-8d5f346ffcd6.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_tacoma_wa_buildings_featureserver-d08e2666-3342-4c02-8f80-279e5910a37d.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_tacoma_wa_buildings_featureserver-d08e2666-3342-4c02-8f80-279e5910a37d.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_tacoma_wa_buildings_featureserver-d08e2666-3342-4c02-8f80-279e5910a37d.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_tacoma_wa_buildings_featureserver-d08e2666-3342-4c02-8f80-279e5910a37d.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_tampa_fl_buildings_featureserver-204ccfc2-0167-4cd7-a8df-3f281d10d5d0.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_tampa_fl_buildings_featureserver-204ccfc2-0167-4cd7-a8df-3f281d10d5d0.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_tampa_fl_buildings_featureserver-204ccfc2-0167-4cd7-a8df-3f281d10d5d0.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_tampa_fl_buildings_featureserver-204ccfc2-0167-4cd7-a8df-3f281d10d5d0.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_wb_zanzibar_buildings_featureserver-66d2a4b2-09ce-46d3-b9c9-a0c7489fefab.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_wb_zanzibar_buildings_featureserver-66d2a4b2-09ce-46d3-b9c9-a0c7489fefab.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_wb_zanzibar_buildings_featureserver-66d2a4b2-09ce-46d3-b9c9-a0c7489fefab.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_wb_zanzibar_buildings_featureserver-66d2a4b2-09ce-46d3-b9c9-a0c7489fefab.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_wb_zanzibar_buildings_featureserver_0-d64a22d3-e6e0-4dc6-ae5c-f9a2ba8f8485.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_wb_zanzibar_buildings_featureserver_0-d64a22d3-e6e0-4dc6-ae5c-f9a2ba8f8485.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_wb_zanzibar_buildings_featureserver_0-d64a22d3-e6e0-4dc6-ae5c-f9a2ba8f8485.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_wb_zanzibar_buildings_featureserver_0-d64a22d3-e6e0-4dc6-ae5c-f9a2ba8f8485.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_williamson_county_tx_buildings_featureserver-6db57544-0cfa-4b2f-8cd3-5845cac15108.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_williamson_county_tx_buildings_featureserver-6db57544-0cfa-4b2f-8cd3-5845cac15108.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_williamson_county_tx_buildings_featureserver-6db57544-0cfa-4b2f-8cd3-5845cac15108.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_williamson_county_tx_buildings_featureserver-6db57544-0cfa-4b2f-8cd3-5845cac15108.json
diff --git a/src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_yavapai_county_az_buildings_featureserver-037b364c-e9e2-4478-8bd9-8bd9a3b3c9aa.json b/src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_yavapai_county_az_buildings_featureserver-037b364c-e9e2-4478-8bd9-8bd9a3b3c9aa.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/do88dok2xjtucxd1_arcgis_rest_services_yavapai_county_az_buildings_featureserver-037b364c-e9e2-4478-8bd9-8bd9a3b3c9aa.json
rename to src/test/resources/mappings/do88dok2xjtucxd1_arcgis_rest_services_yavapai_county_az_buildings_featureserver-037b364c-e9e2-4478-8bd9-8bd9a3b3c9aa.json
diff --git a/src/test/resources/wiremock/mappings/faviconico-0a890cfc-c50c-44be-973b-acf92836e513.json b/src/test/resources/mappings/faviconico-0a890cfc-c50c-44be-973b-acf92836e513.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/faviconico-0a890cfc-c50c-44be-973b-acf92836e513.json
rename to src/test/resources/mappings/faviconico-0a890cfc-c50c-44be-973b-acf92836e513.json
diff --git a/src/test/resources/wiremock/mappings/faviconico-b9f04630-0820-4f01-a541-b9d4226b8f84.json b/src/test/resources/mappings/faviconico-b9f04630-0820-4f01-a541-b9d4226b8f84.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/faviconico-b9f04630-0820-4f01-a541-b9d4226b8f84.json
rename to src/test/resources/mappings/faviconico-b9f04630-0820-4f01-a541-b9d4226b8f84.json
diff --git a/src/test/resources/wiremock/mappings/faviconico-ca7c6f18-2915-4be6-b28a-1729a6217b54.json b/src/test/resources/mappings/faviconico-ca7c6f18-2915-4be6-b28a-1729a6217b54.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/faviconico-ca7c6f18-2915-4be6-b28a-1729a6217b54.json
rename to src/test/resources/mappings/faviconico-ca7c6f18-2915-4be6-b28a-1729a6217b54.json
diff --git a/src/test/resources/wiremock/mappings/josm_mapwithai_json_conflation_serversjson-fb2197f1-81fd-445d-bb90-b6219d187af6.json b/src/test/resources/mappings/josm_mapwithai_json_conflation_serversjson-fb2197f1-81fd-445d-bb90-b6219d187af6.json
similarity index 55%
rename from src/test/resources/wiremock/mappings/josm_mapwithai_json_conflation_serversjson-fb2197f1-81fd-445d-bb90-b6219d187af6.json
rename to src/test/resources/mappings/josm_mapwithai_json_conflation_serversjson-fb2197f1-81fd-445d-bb90-b6219d187af6.json
index 45928773..e92643a8 100644
--- a/src/test/resources/wiremock/mappings/josm_mapwithai_json_conflation_serversjson-fb2197f1-81fd-445d-bb90-b6219d187af6.json
+++ b/src/test/resources/mappings/josm_mapwithai_json_conflation_serversjson-fb2197f1-81fd-445d-bb90-b6219d187af6.json
@@ -7,7 +7,20 @@
},
"response" : {
"status" : 200,
- "body" : "{\n \"Taylor's Address Conflation Server\" : {\n \"categories\" : [\n \"addresses\"\n ],\n \"description\" : \"Originally developed for use with local datasets, it now accepts external datasets for conflation purposes. In the event of a failure, the plugin will use the original dataset.\",\n \"license\" : \"AGPL\",\n \"source\" : \"https://gitlab.com/smocktaylor/serve_osm_files/\",\n \"url\" : \"https://importdata.riverviewtechnologies.com/conflate\"\n }\n}\n",
+ "jsonBody": {
+ "Taylor's Address Conflation Server": {
+ "categories": [
+ "addresses"
+ ],
+ "description": "Originally developed for use with local datasets, it now accepts external datasets for conflation purposes. In the event of a failure, the plugin will use the original dataset.",
+ "license": "AGPL",
+ "source": "{{ request.baseUrl }}/smocktaylor/serve_osm_files/",
+ "url": "{{ request.baseUrl }}/conflate"
+ }
+ },
+ "transformers": [
+ "response-template"
+ ],
"headers" : {
"Accept-Ranges" : "bytes",
"Cache-Control" : "max-age=600",
diff --git a/src/test/resources/mappings/josm_mapwithai_json_sourcesjson-23497750-675c-440a-986a-34dd14b047f8.json b/src/test/resources/mappings/josm_mapwithai_json_sourcesjson-23497750-675c-440a-986a-34dd14b047f8.json
new file mode 100644
index 00000000..87915c09
--- /dev/null
+++ b/src/test/resources/mappings/josm_mapwithai_json_sourcesjson-23497750-675c-440a-986a-34dd14b047f8.json
@@ -0,0 +1,641 @@
+{
+ "id" : "23497750-675c-440a-986a-34dd14b047f8",
+ "name" : "josm_mapwithai_json_sourcesjson",
+ "request" : {
+ "urlPattern" : "\/MapWithAI\/?json\/sources.json",
+ "method" : "GET"
+ },
+ "response" : {
+ "status" : 200,
+ "jsonBody": {
+ "Statewide Aggregate Addresses in Colorado 2019 (Public)": {
+ "countries": {
+ "US-CO": [
+ "addr:housenumber"
+ ]
+ },
+ "license": "Public Domain",
+ "osm_compatible": "yes",
+ "parameters": [],
+ "permission_url": "{{ request.baseUrl }}/wiki/Import/Colorado_Addresses",
+ "url": "{{ request.baseUrl }}/coloradoAddresses/map?bbox={bbox}"
+ },
+ "MapWithAI": {
+ "countries": {
+ "AE": [
+ "highway"
+ ],
+ "AF": [
+ "highway"
+ ],
+ "AG": [
+ "highway"
+ ],
+ "AI": [
+ "highway"
+ ],
+ "AL": [
+ "highway"
+ ],
+ "AM": [
+ "highway"
+ ],
+ "AO": [
+ "highway"
+ ],
+ "AR": [
+ "highway"
+ ],
+ "AT": [
+ "highway"
+ ],
+ "AU": [
+ "highway"
+ ],
+ "AZ": [
+ "highway"
+ ],
+ "BA": [
+ "highway"
+ ],
+ "BB": [
+ "highway"
+ ],
+ "BD": [
+ "highway"
+ ],
+ "BE": [
+ "highway"
+ ],
+ "BF": [
+ "highway"
+ ],
+ "BG": [
+ "highway"
+ ],
+ "BI": [
+ "highway"
+ ],
+ "BJ": [
+ "highway"
+ ],
+ "BL": [
+ "highway"
+ ],
+ "BN": [
+ "highway"
+ ],
+ "BO": [
+ "highway"
+ ],
+ "BR": [
+ "highway"
+ ],
+ "BS": [
+ "highway"
+ ],
+ "BT": [
+ "highway"
+ ],
+ "BW": [
+ "highway"
+ ],
+ "BY": [
+ "highway"
+ ],
+ "BZ": [
+ "highway"
+ ],
+ "CA": [
+ "building",
+ "highway"
+ ],
+ "CD": [
+ "highway"
+ ],
+ "CF": [
+ "highway"
+ ],
+ "CG": [
+ "highway"
+ ],
+ "CH": [
+ "highway"
+ ],
+ "CI": [
+ "highway"
+ ],
+ "CL": [
+ "highway"
+ ],
+ "CM": [
+ "highway"
+ ],
+ "CN": [
+ "highway"
+ ],
+ "CO": [
+ "highway"
+ ],
+ "CR": [
+ "highway"
+ ],
+ "CU": [
+ "highway"
+ ],
+ "CY": [
+ "highway"
+ ],
+ "CZ": [
+ "highway"
+ ],
+ "DE": [
+ "highway"
+ ],
+ "DJ": [
+ "highway"
+ ],
+ "DK": [
+ "highway"
+ ],
+ "DM": [
+ "highway"
+ ],
+ "DO": [
+ "highway"
+ ],
+ "DZ": [
+ "highway"
+ ],
+ "EC": [
+ "highway"
+ ],
+ "EE": [
+ "highway"
+ ],
+ "EG": [
+ "highway"
+ ],
+ "EH": [
+ "highway"
+ ],
+ "ER": [
+ "highway"
+ ],
+ "ES": [
+ "highway"
+ ],
+ "ET": [
+ "highway"
+ ],
+ "FK": [
+ "highway"
+ ],
+ "FI": [
+ "highway"
+ ],
+ "FJ": [
+ "highway"
+ ],
+ "FR": [
+ "highway"
+ ],
+ "GA": [
+ "highway"
+ ],
+ "GB": [
+ "highway"
+ ],
+ "GD": [
+ "highway"
+ ],
+ "GE": [
+ "highway"
+ ],
+ "GF": [
+ "highway"
+ ],
+ "GH": [
+ "highway"
+ ],
+ "GM": [
+ "highway"
+ ],
+ "GN": [
+ "highway"
+ ],
+ "GP": [
+ "highway"
+ ],
+ "GQ": [
+ "highway"
+ ],
+ "GR": [
+ "highway"
+ ],
+ "GT": [
+ "highway"
+ ],
+ "GW": [
+ "highway"
+ ],
+ "GY": [
+ "highway"
+ ],
+ "HN": [
+ "highway"
+ ],
+ "HR": [
+ "highway"
+ ],
+ "HT": [
+ "highway"
+ ],
+ "HU": [
+ "highway"
+ ],
+ "ID": [
+ "highway"
+ ],
+ "IE": [
+ "highway"
+ ],
+ "IL": [
+ "highway"
+ ],
+ "IN": [
+ "highway"
+ ],
+ "IQ": [
+ "highway"
+ ],
+ "IS": [
+ "highway"
+ ],
+ "IT": [
+ "highway"
+ ],
+ "JM": [
+ "highway"
+ ],
+ "JO": [
+ "highway"
+ ],
+ "JP": [
+ "highway"
+ ],
+ "KE": [
+ "highway"
+ ],
+ "KG": [
+ "highway"
+ ],
+ "KH": [
+ "highway"
+ ],
+ "KN": [
+ "highway"
+ ],
+ "KY": [
+ "highway"
+ ],
+ "KR": [
+ "highway"
+ ],
+ "KW": [
+ "highway"
+ ],
+ "KZ": [
+ "highway"
+ ],
+ "LA": [
+ "highway"
+ ],
+ "LB": [
+ "highway"
+ ],
+ "LC": [
+ "highway"
+ ],
+ "LK": [
+ "highway"
+ ],
+ "LR": [
+ "highway"
+ ],
+ "LS": [
+ "highway"
+ ],
+ "LT": [
+ "highway"
+ ],
+ "LU": [
+ "highway"
+ ],
+ "LV": [
+ "highway"
+ ],
+ "LY": [
+ "highway"
+ ],
+ "MA": [
+ "highway"
+ ],
+ "MD": [
+ "highway"
+ ],
+ "ME": [
+ "highway"
+ ],
+ "MF": [
+ "highway"
+ ],
+ "MG": [
+ "highway"
+ ],
+ "MK": [
+ "highway"
+ ],
+ "ML": [
+ "highway"
+ ],
+ "MM": [
+ "highway"
+ ],
+ "MN": [
+ "highway"
+ ],
+ "MQ": [
+ "highway"
+ ],
+ "MR": [
+ "highway"
+ ],
+ "MS": [
+ "highway"
+ ],
+ "MW": [
+ "highway"
+ ],
+ "MX": [
+ "highway"
+ ],
+ "MY": [
+ "highway"
+ ],
+ "MZ": [
+ "highway"
+ ],
+ "NA": [
+ "highway"
+ ],
+ "NE": [
+ "highway"
+ ],
+ "NG": [
+ "highway"
+ ],
+ "NI": [
+ "highway"
+ ],
+ "NL": [
+ "highway"
+ ],
+ "NL-BQ2": [
+ "highway"
+ ],
+ "NL-BQ3": [
+ "highway"
+ ],
+ "NO": [
+ "highway"
+ ],
+ "NP": [
+ "highway"
+ ],
+ "NZ": [
+ "highway"
+ ],
+ "OM": [
+ "highway"
+ ],
+ "PA": [
+ "highway"
+ ],
+ "PE": [
+ "highway"
+ ],
+ "PF": [
+ "highway"
+ ],
+ "PG": [
+ "highway"
+ ],
+ "PH": [
+ "highway"
+ ],
+ "PK": [
+ "highway"
+ ],
+ "PL": [
+ "highway"
+ ],
+ "PR": [
+ "highway"
+ ],
+ "PS": [
+ "highway"
+ ],
+ "PT": [
+ "highway"
+ ],
+ "PY": [
+ "highway"
+ ],
+ "QA": [
+ "highway"
+ ],
+ "RO": [
+ "highway"
+ ],
+ "RS": [
+ "highway"
+ ],
+ "RS-KM": [
+ "highway"
+ ],
+ "RU": [
+ "highway"
+ ],
+ "RW": [
+ "highway"
+ ],
+ "SA": [
+ "highway"
+ ],
+ "SB": [
+ "highway"
+ ],
+ "SD": [
+ "highway"
+ ],
+ "SE": [
+ "highway"
+ ],
+ "SG": [
+ "highway"
+ ],
+ "SI": [
+ "highway"
+ ],
+ "SK": [
+ "highway"
+ ],
+ "SL": [
+ "highway"
+ ],
+ "SN": [
+ "highway"
+ ],
+ "SO": [
+ "highway"
+ ],
+ "SR": [
+ "highway"
+ ],
+ "SS": [
+ "highway"
+ ],
+ "ST": [
+ "highway"
+ ],
+ "SV": [
+ "highway"
+ ],
+ "SX": [
+ "highway"
+ ],
+ "SZ": [
+ "highway"
+ ],
+ "TC": [
+ "highway"
+ ],
+ "TD": [
+ "highway"
+ ],
+ "TG": [
+ "highway"
+ ],
+ "TH": [
+ "highway"
+ ],
+ "TJ": [
+ "highway"
+ ],
+ "TL": [
+ "highway"
+ ],
+ "TM": [
+ "highway"
+ ],
+ "TN": [
+ "highway"
+ ],
+ "TR": [
+ "highway"
+ ],
+ "TT": [
+ "highway"
+ ],
+ "TW": [
+ "highway"
+ ],
+ "TZ": [
+ "building",
+ "highway"
+ ],
+ "UA": [
+ "highway"
+ ],
+ "UG": [
+ "building",
+ "highway"
+ ],
+ "US": [
+ "building",
+ "highway"
+ ],
+ "US-AK": [
+ "building"
+ ],
+ "US-HI": [
+ "building"
+ ],
+ "UY": [
+ "highway"
+ ],
+ "UZ": [
+ "highway"
+ ],
+ "VC": [
+ "highway"
+ ],
+ "VE": [
+ "highway"
+ ],
+ "VG": [
+ "highway"
+ ],
+ "VN": [
+ "highway"
+ ],
+ "VU": [
+ "highway"
+ ],
+ "YE": [
+ "highway"
+ ],
+ "ZA": [
+ "highway"
+ ],
+ "ZM": [
+ "highway"
+ ],
+ "ZW": [
+ "highway"
+ ]
+ },
+ "default": true,
+ "license": "ODBL",
+ "osm_compatible": "yes",
+ "parameters": [
+ {
+ "description": "buildings",
+ "enabled": true,
+ "parameter": "result_type=road_building_vector_xml"
+ }
+ ],
+ "permission_url": "{{ request.baseUrl }}/facebookmicrosites/Open-Mapping-At-Facebook/wiki/FAQ",
+ "terms_of_use_url": "{{ request.baseUrl }}/doc/license/MapWithAILicense.pdf",
+ "privacy_policy_url": "{{ request.baseUrl }}/doc/license/MapWithAIPrivacyPolicy.pdf#page=3",
+ "url": "{{ request.baseUrl }}/maps/ml_roads?conflate_with_osm=true&theme=ml_road_vector&collaborator=josm&token=ASb3N5o9HbX8QWn8G_NtHIRQaYv3nuG2r7_f3vnGld3KhZNCxg57IsaQyssIaEw5rfRNsPpMwg4TsnrSJtIJms5m&hash=ASawRla3rBcwEjY4HIY&bbox={bbox}"
+ }
+ },
+ "transformers": [
+ "response-template"
+ ],
+ "headers" : {
+ "Accept-Ranges" : "bytes",
+ "Cache-Control" : "max-age=600",
+ "Content-Type" : "application/json",
+ "Expires" : "Tue, 21 Apr 2020 19:51:40 UTC",
+ "Last-Modified" : "Tue, 21 Apr 2020 17:34:08 GMT",
+ "Vary" : "Origin",
+ "Date" : "Tue, 21 Apr 2020 19:41:40 GMT"
+ }
+ },
+ "uuid" : "23497750-675c-440a-986a-34dd14b047f8",
+ "persistent" : true,
+ "insertionIndex" : 1
+}
diff --git a/src/test/resources/wiremock/mappings/josmfile-Styles-MapWithAI.json b/src/test/resources/mappings/josmfile-Styles-MapWithAI.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/josmfile-Styles-MapWithAI.json
rename to src/test/resources/mappings/josmfile-Styles-MapWithAI.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-04b70b03-d148-4e3d-a1fc-98334cd10e64.json b/src/test/resources/mappings/maps_ml_roads-04b70b03-d148-4e3d-a1fc-98334cd10e64.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-04b70b03-d148-4e3d-a1fc-98334cd10e64.json
rename to src/test/resources/mappings/maps_ml_roads-04b70b03-d148-4e3d-a1fc-98334cd10e64.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-0bc0c6c3-8e38-4da4-8f85-c07bde3ef54d.json b/src/test/resources/mappings/maps_ml_roads-0bc0c6c3-8e38-4da4-8f85-c07bde3ef54d.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-0bc0c6c3-8e38-4da4-8f85-c07bde3ef54d.json
rename to src/test/resources/mappings/maps_ml_roads-0bc0c6c3-8e38-4da4-8f85-c07bde3ef54d.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-146193dd-3082-495b-b350-8164e2858f8d.json b/src/test/resources/mappings/maps_ml_roads-146193dd-3082-495b-b350-8164e2858f8d.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-146193dd-3082-495b-b350-8164e2858f8d.json
rename to src/test/resources/mappings/maps_ml_roads-146193dd-3082-495b-b350-8164e2858f8d.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-3098faf3-c028-43c6-9263-42f1cab7c161.json b/src/test/resources/mappings/maps_ml_roads-3098faf3-c028-43c6-9263-42f1cab7c161.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-3098faf3-c028-43c6-9263-42f1cab7c161.json
rename to src/test/resources/mappings/maps_ml_roads-3098faf3-c028-43c6-9263-42f1cab7c161.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-4df1e72e-a62e-48b6-806d-99fd74956742.json b/src/test/resources/mappings/maps_ml_roads-4df1e72e-a62e-48b6-806d-99fd74956742.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-4df1e72e-a62e-48b6-806d-99fd74956742.json
rename to src/test/resources/mappings/maps_ml_roads-4df1e72e-a62e-48b6-806d-99fd74956742.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-53133862-d606-4976-b016-a35be71df3fb.json b/src/test/resources/mappings/maps_ml_roads-53133862-d606-4976-b016-a35be71df3fb.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-53133862-d606-4976-b016-a35be71df3fb.json
rename to src/test/resources/mappings/maps_ml_roads-53133862-d606-4976-b016-a35be71df3fb.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-580f7b5b-cb9a-4092-8a39-bf8b714e6efe.json b/src/test/resources/mappings/maps_ml_roads-580f7b5b-cb9a-4092-8a39-bf8b714e6efe.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-580f7b5b-cb9a-4092-8a39-bf8b714e6efe.json
rename to src/test/resources/mappings/maps_ml_roads-580f7b5b-cb9a-4092-8a39-bf8b714e6efe.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-715854d4-ba75-4289-89fe-9352c3d3ed6b.json b/src/test/resources/mappings/maps_ml_roads-715854d4-ba75-4289-89fe-9352c3d3ed6b.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-715854d4-ba75-4289-89fe-9352c3d3ed6b.json
rename to src/test/resources/mappings/maps_ml_roads-715854d4-ba75-4289-89fe-9352c3d3ed6b.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-9b87a83b-8600-4f49-9362-9bb066b02133.json b/src/test/resources/mappings/maps_ml_roads-9b87a83b-8600-4f49-9362-9bb066b02133.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-9b87a83b-8600-4f49-9362-9bb066b02133.json
rename to src/test/resources/mappings/maps_ml_roads-9b87a83b-8600-4f49-9362-9bb066b02133.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-ce324a60-116f-48ae-8999-fa4321b68f18.json b/src/test/resources/mappings/maps_ml_roads-ce324a60-116f-48ae-8999-fa4321b68f18.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-ce324a60-116f-48ae-8999-fa4321b68f18.json
rename to src/test/resources/mappings/maps_ml_roads-ce324a60-116f-48ae-8999-fa4321b68f18.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-e3da5e5b-126f-44e1-8411-93eff12bd08a.json b/src/test/resources/mappings/maps_ml_roads-e3da5e5b-126f-44e1-8411-93eff12bd08a.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-e3da5e5b-126f-44e1-8411-93eff12bd08a.json
rename to src/test/resources/mappings/maps_ml_roads-e3da5e5b-126f-44e1-8411-93eff12bd08a.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-e543fb8b-a680-4a1d-9f90-a793b7a7a6a6.json b/src/test/resources/mappings/maps_ml_roads-e543fb8b-a680-4a1d-9f90-a793b7a7a6a6.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-e543fb8b-a680-4a1d-9f90-a793b7a7a6a6.json
rename to src/test/resources/mappings/maps_ml_roads-e543fb8b-a680-4a1d-9f90-a793b7a7a6a6.json
diff --git a/src/test/resources/wiremock/mappings/maps_ml_roads-f72200ba-e99d-481a-90e9-c4e7ddd3398b.json b/src/test/resources/mappings/maps_ml_roads-f72200ba-e99d-481a-90e9-c4e7ddd3398b.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/maps_ml_roads-f72200ba-e99d-481a-90e9-c4e7ddd3398b.json
rename to src/test/resources/mappings/maps_ml_roads-f72200ba-e99d-481a-90e9-c4e7ddd3398b.json
diff --git a/src/test/resources/wiremock/mappings/sharing_rest_content_groups_bdf6c800b3ae453b9db239e03d7c1727_search-2b3ba100-8f68-4bd8-977f-86cf5c5212b2.json b/src/test/resources/mappings/sharing_rest_content_groups_bdf6c800b3ae453b9db239e03d7c1727_search-2b3ba100-8f68-4bd8-977f-86cf5c5212b2.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/sharing_rest_content_groups_bdf6c800b3ae453b9db239e03d7c1727_search-2b3ba100-8f68-4bd8-977f-86cf5c5212b2.json
rename to src/test/resources/mappings/sharing_rest_content_groups_bdf6c800b3ae453b9db239e03d7c1727_search-2b3ba100-8f68-4bd8-977f-86cf5c5212b2.json
diff --git a/src/test/resources/wiremock/mappings/sharing_rest_content_groups_bdf6c800b3ae453b9db239e03d7c1727_search-b603ddec-a465-4f56-8406-bfef84c6e30f.json b/src/test/resources/mappings/sharing_rest_content_groups_bdf6c800b3ae453b9db239e03d7c1727_search-b603ddec-a465-4f56-8406-bfef84c6e30f.json
similarity index 100%
rename from src/test/resources/wiremock/mappings/sharing_rest_content_groups_bdf6c800b3ae453b9db239e03d7c1727_search-b603ddec-a465-4f56-8406-bfef84c6e30f.json
rename to src/test/resources/mappings/sharing_rest_content_groups_bdf6c800b3ae453b9db239e03d7c1727_search-b603ddec-a465-4f56-8406-bfef84c6e30f.json
diff --git a/src/test/resources/wiremock/mappings/josm_mapwithai_json_sourcesjson-23497750-675c-440a-986a-34dd14b047f8.json b/src/test/resources/wiremock/mappings/josm_mapwithai_json_sourcesjson-23497750-675c-440a-986a-34dd14b047f8.json
deleted file mode 100644
index c0a6a1af..00000000
--- a/src/test/resources/wiremock/mappings/josm_mapwithai_json_sourcesjson-23497750-675c-440a-986a-34dd14b047f8.json
+++ /dev/null
@@ -1,24 +0,0 @@
-{
- "id" : "23497750-675c-440a-986a-34dd14b047f8",
- "name" : "josm_mapwithai_json_sourcesjson",
- "request" : {
- "urlPattern" : "\/MapWithAI\/?json\/sources.json",
- "method" : "GET"
- },
- "response" : {
- "status" : 200,
- "body" : "{\n \"Statewide Aggregate Addresses in Colorado 2019 (Public)\": {\n \"countries\": {\n \"US-CO\": [\"addr:housenumber\"]\n },\n \"license\": \"Public Domain\",\n \"osm_compatible\": \"yes\",\n \"parameters\": [],\n \"permission_url\": \"https://wiki.openstreetmap.org/wiki/Import/Colorado_Addresses\",\n \"url\": \"https://importdata.riverviewtechnologies.com/coloradoAddresses/map?bbox={bbox}\"\n },\n \"MapWithAI\": {\n \"countries\": {\n \"AE\": [\"highway\"],\n \"AF\": [\"highway\"],\n \"AG\": [\"highway\"],\n \"AI\": [\"highway\"],\n \"AL\": [\"highway\"],\n \"AM\": [\"highway\"],\n \"AO\": [\"highway\"],\n \"AR\": [\"highway\"],\n \"AT\": [\"highway\"],\n \"AU\": [\"highway\"],\n \"AZ\": [\"highway\"],\n \"BA\": [\"highway\"],\n \"BB\": [\"highway\"],\n \"BD\": [\"highway\"],\n \"BE\": [\"highway\"],\n \"BF\": [\"highway\"],\n \"BG\": [\"highway\"],\n \"BI\": [\"highway\"],\n \"BJ\": [\"highway\"],\n \"BL\": [\"highway\"],\n \"BN\": [\"highway\"],\n \"BO\": [\"highway\"],\n \"BR\": [\"highway\"],\n \"BS\": [\"highway\"],\n \"BT\": [\"highway\"],\n \"BW\": [\"highway\"],\n \"BY\": [\"highway\"],\n \"BZ\": [\"highway\"],\n \"CA\": [\"building\", \"highway\"],\n \"CD\": [\"highway\"],\n \"CF\": [\"highway\"],\n \"CG\": [\"highway\"],\n \"CH\": [\"highway\"],\n \"CI\": [\"highway\"],\n \"CL\": [\"highway\"],\n \"CM\": [\"highway\"],\n \"CN\": [\"highway\"],\n \"CO\": [\"highway\"],\n \"CR\": [\"highway\"],\n \"CU\": [\"highway\"],\n \"CY\": [\"highway\"],\n \"CZ\": [\"highway\"],\n \"DE\": [\"highway\"],\n \"DJ\": [\"highway\"],\n \"DK\": [\"highway\"],\n \"DM\": [\"highway\"],\n \"DO\": [\"highway\"],\n \"DZ\": [\"highway\"],\n \"EC\": [\"highway\"],\n \"EE\": [\"highway\"],\n \"EG\": [\"highway\"],\n \"EH\": [\"highway\"],\n \"ER\": [\"highway\"],\n \"ES\": [\"highway\"],\n \"ET\": [\"highway\"],\n \"FK\": [\"highway\"],\n \"FI\": [\"highway\"],\n \"FJ\": [\"highway\"],\n \"FR\": [\"highway\"],\n \"GA\": [\"highway\"],\n \"GB\": [\"highway\"],\n \"GD\": [\"highway\"],\n \"GE\": [\"highway\"],\n \"GF\": [\"highway\"],\n \"GH\": [\"highway\"],\n \"GM\": [\"highway\"],\n \"GN\": [\"highway\"],\n \"GP\": [\"highway\"],\n \"GQ\": [\"highway\"],\n \"GR\": [\"highway\"],\n \"GT\": [\"highway\"],\n \"GW\": [\"highway\"],\n \"GY\": [\"highway\"],\n \"HN\": [\"highway\"],\n \"HR\": [\"highway\"],\n \"HT\": [\"highway\"],\n \"HU\": [\"highway\"],\n \"ID\": [\"highway\"],\n \"IE\": [\"highway\"],\n \"IL\": [\"highway\"],\n \"IN\": [\"highway\"],\n \"IQ\": [\"highway\"],\n \"IS\": [\"highway\"],\n \"IT\": [\"highway\"],\n \"JM\": [\"highway\"],\n \"JO\": [\"highway\"],\n \"JP\": [\"highway\"],\n \"KE\": [\"highway\"],\n \"KG\": [\"highway\"],\n \"KH\": [\"highway\"],\n \"KN\": [\"highway\"],\n \"KY\": [\"highway\"],\n \"KR\": [\"highway\"],\n \"KW\": [\"highway\"],\n \"KZ\": [\"highway\"],\n \"LA\": [\"highway\"],\n \"LB\": [\"highway\"],\n \"LC\": [\"highway\"],\n \"LK\": [\"highway\"],\n \"LR\": [\"highway\"],\n \"LS\": [\"highway\"],\n \"LT\": [\"highway\"],\n \"LU\": [\"highway\"],\n \"LV\": [\"highway\"],\n \"LY\": [\"highway\"],\n \"MA\": [\"highway\"],\n \"MD\": [\"highway\"],\n \"ME\": [\"highway\"],\n \"MF\": [\"highway\"],\n \"MG\": [\"highway\"],\n \"MK\": [\"highway\"],\n \"ML\": [\"highway\"],\n \"MM\": [\"highway\"],\n \"MN\": [\"highway\"],\n \"MQ\": [\"highway\"],\n \"MR\": [\"highway\"],\n \"MS\": [\"highway\"],\n \"MW\": [\"highway\"],\n \"MX\": [\"highway\"],\n \"MY\": [\"highway\"],\n \"MZ\": [\"highway\"],\n \"NA\": [\"highway\"],\n \"NE\": [\"highway\"],\n \"NG\": [\"highway\"],\n \"NI\": [\"highway\"],\n \"NL\": [\"highway\"],\n \"NL-BQ2\": [\"highway\"],\n \"NL-BQ3\": [\"highway\"],\n \"NO\": [\"highway\"],\n \"NP\": [\"highway\"],\n \"NZ\": [\"highway\"],\n \"OM\": [\"highway\"],\n \"PA\": [\"highway\"],\n \"PE\": [\"highway\"],\n \"PF\": [\"highway\"],\n \"PG\": [\"highway\"],\n \"PH\": [\"highway\"],\n \"PK\": [\"highway\"],\n \"PL\": [\"highway\"],\n \"PR\": [\"highway\"],\n \"PS\": [\"highway\"],\n \"PT\": [\"highway\"],\n \"PY\": [\"highway\"],\n \"QA\": [\"highway\"],\n \"RO\": [\"highway\"],\n \"RS\": [\"highway\"],\n \"RS-KM\": [\"highway\"],\n \"RU\": [\"highway\"],\n \"RW\": [\"highway\"],\n \"SA\": [\"highway\"],\n \"SB\": [\"highway\"],\n \"SD\": [\"highway\"],\n \"SE\": [\"highway\"],\n \"SG\": [\"highway\"],\n \"SI\": [\"highway\"],\n \"SK\": [\"highway\"],\n \"SL\": [\"highway\"],\n \"SN\": [\"highway\"],\n \"SO\": [\"highway\"],\n \"SR\": [\"highway\"],\n \"SS\": [\"highway\"],\n \"ST\": [\"highway\"],\n \"SV\": [\"highway\"],\n \"SX\": [\"highway\"],\n \"SZ\": [\"highway\"],\n \"TC\": [\"highway\"],\n \"TD\": [\"highway\"],\n \"TG\": [\"highway\"],\n \"TH\": [\"highway\"],\n \"TJ\": [\"highway\"],\n \"TL\": [\"highway\"],\n \"TM\": [\"highway\"],\n \"TN\": [\"highway\"],\n \"TR\": [\"highway\"],\n \"TT\": [\"highway\"],\n \"TW\": [\"highway\"],\n \"TZ\": [\"building\", \"highway\"],\n \"UA\": [\"highway\"],\n \"UG\": [\"building\", \"highway\"],\n \"US\": [\"building\", \"highway\"],\n \"US-AK\": [\"building\"],\n \"US-HI\": [\"building\"],\n \"UY\": [\"highway\"],\n \"UZ\": [\"highway\"],\n \"VC\": [\"highway\"],\n \"VE\": [\"highway\"],\n \"VG\": [\"highway\"],\n \"VN\": [\"highway\"],\n \"VU\": [\"highway\"],\n \"YE\": [\"highway\"],\n \"ZA\": [\"highway\"],\n \"ZM\": [\"highway\"],\n \"ZW\": [\"highway\"]\n },\n \"default\": true,\n \"license\": \"ODBL\",\n \"osm_compatible\": \"yes\",\n \"parameters\": [{\n \"description\": \"buildings\",\n \"enabled\": true,\n \"parameter\": \"result_type=road_building_vector_xml\"\n }],\n \"permission_url\": \"https://github.com/facebookmicrosites/Open-Mapping-At-Facebook/wiki/FAQ\",\n \"terms_of_use_url\": \"https://mapwith.ai/doc/license/MapWithAILicense.pdf\",\n \"privacy_policy_url\": \"https://mapwith.ai/doc/license/MapWithAIPrivacyPolicy.pdf#page=3\",\n \"url\": \"https://www.mapwith.ai/maps/ml_roads?conflate_with_osm=true&theme=ml_road_vector&collaborator=josm&token=ASb3N5o9HbX8QWn8G_NtHIRQaYv3nuG2r7_f3vnGld3KhZNCxg57IsaQyssIaEw5rfRNsPpMwg4TsnrSJtIJms5m&hash=ASawRla3rBcwEjY4HIY&bbox={bbox}\"\n }\n}\n",
- "headers" : {
- "Accept-Ranges" : "bytes",
- "Cache-Control" : "max-age=600",
- "Content-Type" : "application/json",
- "Expires" : "Tue, 21 Apr 2020 19:51:40 UTC",
- "Last-Modified" : "Tue, 21 Apr 2020 17:34:08 GMT",
- "Vary" : "Origin",
- "Date" : "Tue, 21 Apr 2020 19:41:40 GMT"
- }
- },
- "uuid" : "23497750-675c-440a-986a-34dd14b047f8",
- "persistent" : true,
- "insertionIndex" : 1
-}
diff --git a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/actions/AddMapWithAILayerActionTest.java b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/actions/AddMapWithAILayerActionTest.java
index ac816cdb..897f03a7 100644
--- a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/actions/AddMapWithAILayerActionTest.java
+++ b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/actions/AddMapWithAILayerActionTest.java
@@ -24,6 +24,7 @@
import javax.swing.Action;
import javax.swing.ImageIcon;
+import com.github.tomakehurst.wiremock.junit5.WireMockRuntimeInfo;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.RegisterExtension;
@@ -74,14 +75,11 @@ public ThreadSyncMWAI() {
@RegisterExtension
static ThreadSyncMWAI threadSync = new ThreadSyncMWAI();
- @BasicWiremock
- WireMockServer wireMockServer;
-
private static MapWithAIInfo info;
private static MapWithAIInfo backupInfo;
@BeforeEach
- void setup() {
+ void setup(WireMockRuntimeInfo wireMockRuntimeInfo) {
final Map parameterMap = new HashMap<>();
final AnythingPattern anythingPattern = new AnythingPattern();
parameterMap.put("geometryType", anythingPattern);
@@ -91,7 +89,7 @@ void setup() {
parameterMap.put("outfields", new EqualToPattern("*"));
parameterMap.put("result_type", new EqualToPattern("road_building_vector_xml"));
parameterMap.put("resultOffset", anythingPattern);
- wireMockServer.stubFor(
+ wireMockRuntimeInfo.getWireMock().register(
WireMock.get(new UrlPathPattern(new EqualToPattern("/query"), false)).withQueryParams(parameterMap)
.willReturn(WireMock.aResponse()
.withBody(Json.createObjectBuilder().add("type", "FeatureCollection")
@@ -142,7 +140,7 @@ void testAddMapWithAILayerActionTest() {
}
@Test
- void testRemoteIcon() throws IOException {
+ void testRemoteIcon(WireMockRuntimeInfo wireMockRuntimeInfo) throws IOException {
final ImageIcon blankImage = ImageProvider.createBlankIcon(ImageProvider.ImageSizes.LARGEICON);
final ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
// BufferedImage is what the current implementation uses. Otherwise, we will
@@ -150,10 +148,9 @@ void testRemoteIcon() throws IOException {
final BufferedImage bi = assertInstanceOf(BufferedImage.class, blankImage.getImage());
ImageIO.write(bi, "png", byteArrayOutputStream);
byte[] originalImage = byteArrayOutputStream.toByteArray();
- wireMockServer.addStubMapping(
- wireMockServer.stubFor(WireMock.get("/icon").willReturn(WireMock.aResponse().withBody(originalImage))));
+ wireMockRuntimeInfo.getWireMock().register(WireMock.get("/icon").willReturn(WireMock.aResponse().withBody(originalImage)));
final MapWithAIInfo remoteInfo = new MapWithAIInfo(info);
- remoteInfo.setIcon(wireMockServer.baseUrl() + "/icon");
+ remoteInfo.setIcon(wireMockRuntimeInfo.getHttpBaseUrl() + "/icon");
final AddMapWithAILayerAction action = new AddMapWithAILayerAction(remoteInfo);
threadSync.threadSync();
final Object image = action.getValue(Action.LARGE_ICON_KEY);
@@ -166,7 +163,7 @@ void testRemoteIcon() throws IOException {
}
@Test
- void testNonRegression22683() {
+ void testNonRegression22683(WireMockRuntimeInfo wireMockRuntimeInfo) {
final OsmDataLayer layer = new OsmDataLayer(new DataSet(), "testNonRegression22683", null);
layer.getDataSet().addDataSource(new DataSource(new Bounds(0, 0, 0.001, 0.001), "Area 1"));
layer.getDataSet().addDataSource(new DataSource(new Bounds(-0.001, -0.001, 0, 0), "Area 2"));
@@ -190,7 +187,7 @@ public void close() {
};
Logging.getLogger().addHandler(testHandler);
try {
- info.setUrl(wireMockServer.baseUrl());
+ info.setUrl(wireMockRuntimeInfo.getHttpBaseUrl());
info.setSourceType(MapWithAIType.ESRI_FEATURE_SERVER);
final AddMapWithAILayerAction action = new AddMapWithAILayerAction(info);
Logging.clearLastErrorAndWarnings();
diff --git a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/backend/BoundingBoxMapWithAIDownloaderTest.java b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/backend/BoundingBoxMapWithAIDownloaderTest.java
index ec2f33fb..d7b1321c 100644
--- a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/backend/BoundingBoxMapWithAIDownloaderTest.java
+++ b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/backend/BoundingBoxMapWithAIDownloaderTest.java
@@ -5,8 +5,11 @@
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
+import java.util.List;
import java.util.stream.Collectors;
+import com.github.tomakehurst.wiremock.junit5.WireMockRuntimeInfo;
+import com.github.tomakehurst.wiremock.stubbing.ServeEvent;
import org.junit.jupiter.api.Test;
import org.openstreetmap.josm.data.Bounds;
import org.openstreetmap.josm.data.osm.DataSet;
@@ -17,12 +20,9 @@
import org.openstreetmap.josm.plugins.mapwithai.testutils.annotations.MapWithAIConfig;
import org.openstreetmap.josm.plugins.mapwithai.testutils.annotations.Wiremock;
import org.openstreetmap.josm.testutils.annotations.BasicPreferences;
-import org.openstreetmap.josm.testutils.annotations.BasicWiremock;
import org.openstreetmap.josm.testutils.annotations.HTTP;
import org.openstreetmap.josm.testutils.annotations.OsmApi;
-import com.github.tomakehurst.wiremock.WireMockServer;
-import com.github.tomakehurst.wiremock.admin.model.GetServeEventsResult;
import com.github.tomakehurst.wiremock.admin.model.ServeEventQuery;
import com.github.tomakehurst.wiremock.client.WireMock;
import com.github.tomakehurst.wiremock.http.Request;
@@ -46,35 +46,32 @@
class BoundingBoxMapWithAIDownloaderTest {
private static final String TEST_DATA = "";
- @BasicWiremock
- public WireMockServer wireMockServer;
-
@Test
- void testThirdPartyConflation() {
+ void testThirdPartyConflation(WireMockRuntimeInfo wireMockRuntimeInfo) {
MapWithAIInfo.THIRD_PARTY_CONFLATE.put(true);
final MapWithAIInfo info = new MapWithAIInfo("testThirdPartyConflation",
- this.wireMockServer.baseUrl() + "/testThirdPartyConflation");
+ wireMockRuntimeInfo.getHttpBaseUrl() + "/testThirdPartyConflation");
// ADDRESS has a default /conflate endpoint from a mocked copy of conflation
// servers.
info.setCategory(MapWithAICategory.ADDRESS);
final Bounds downloadBounds = new Bounds(-10, -10, 10, 10);
final BoundingBoxMapWithAIDownloader boundingBoxMapWithAIDownloader = new BoundingBoxMapWithAIDownloader(
downloadBounds, info, false);
- this.wireMockServer.stubFor(
+ wireMockRuntimeInfo.getWireMock().register(
WireMock.get("/testThirdPartyConflation").willReturn(WireMock.aResponse().withBody(TEST_DATA)));
- final StubMapping conflationStub = this.wireMockServer
- .stubFor(WireMock.post("/conflate").willReturn(WireMock.aResponse()
+ final StubMapping conflationStub = wireMockRuntimeInfo.getWireMock()
+ .register(WireMock.post("/conflate").willReturn(WireMock.aResponse()
.withBody("")));
final DataSet ds = assertDoesNotThrow(
() -> boundingBoxMapWithAIDownloader.parseOsm(NullProgressMonitor.INSTANCE));
assertEquals(1, ds.allPrimitives().size());
assertEquals(1L, ds.allPrimitives().iterator().next().getPrimitiveId().getUniqueId());
- final GetServeEventsResult serveEvents = this.wireMockServer
+ final List serveEvents = wireMockRuntimeInfo.getWireMock()
.getServeEvents(ServeEventQuery.forStubMapping(conflationStub));
- assertEquals(1, serveEvents.getRequests().size());
- final LoggedRequest request = serveEvents.getRequests().get(0).getRequest();
+ assertEquals(1, serveEvents.size());
+ final LoggedRequest request = serveEvents.get(0).getRequest();
assertEquals(1, request.getParts().size(),
request.getParts().stream().map(Request.Part::getName).collect(Collectors.joining(",")));
assertNotNull(request.getPart("external"));
@@ -85,29 +82,29 @@ void testThirdPartyConflation() {
* MapWithAI servers
*/
@Test
- void testNonRegression22624() {
+ void testNonRegression22624(WireMockRuntimeInfo wireMockRuntimeInfo) {
MapWithAIInfo.THIRD_PARTY_CONFLATE.put(true);
MapWithAIInfo info = new MapWithAIInfo("testNonRegression22624",
- this.wireMockServer.baseUrl() + "/no-conflation?bbox={bbox}",
+ wireMockRuntimeInfo.getHttpBaseUrl() + "/no-conflation?bbox={bbox}",
MapWithAIType.ESRI_FEATURE_SERVER.getTypeString(), null, "testNonRegression22624");
- info.setConflationUrl(this.wireMockServer.baseUrl() + "/conflation?bbox={bbox}");
+ info.setConflationUrl(wireMockRuntimeInfo.getHttpBaseUrl() + "/conflation?bbox={bbox}");
info.setConflation(true);
final Bounds downloadBounds = new Bounds(-10, -10, 10, 10);
final BoundingBoxMapWithAIDownloader boundingBoxMapWithAIDownloader = new BoundingBoxMapWithAIDownloader(
downloadBounds, info, false);
- StubMapping noConflation = this.wireMockServer
- .stubFor(WireMock.get("/no-conflation").willReturn(WireMock.badRequest()));
- StubMapping resultOffset = this.wireMockServer.stubFor(
+ StubMapping noConflation = wireMockRuntimeInfo.getWireMock()
+ .register(WireMock.get("/no-conflation").willReturn(WireMock.badRequest()));
+ StubMapping resultOffset = wireMockRuntimeInfo.getWireMock().register(
WireMock.get(WireMock.urlPathEqualTo("/conflation")).withQueryParam("bbox", new AnythingPattern())
.withQueryParam("resultOffset", new EqualToPattern("0")).willReturn(WireMock.badRequest()));
- StubMapping noResultOffset = this.wireMockServer.stubFor(WireMock.get(WireMock.urlPathEqualTo("/conflation"))
+ StubMapping noResultOffset = wireMockRuntimeInfo.getWireMock().register(WireMock.get(WireMock.urlPathEqualTo("/conflation"))
.withQueryParam("bbox", new AnythingPattern()).withQueryParam("resultOffset", AbsentPattern.ABSENT)
.willReturn(WireMock.aResponse().withBody(TEST_DATA)));
assertDoesNotThrow(() -> boundingBoxMapWithAIDownloader.parseOsm(NullProgressMonitor.INSTANCE));
- this.wireMockServer.verify(0, RequestPatternBuilder.forCustomMatcher(noConflation.getRequest()));
- this.wireMockServer.verify(0, RequestPatternBuilder.forCustomMatcher(resultOffset.getRequest()));
- this.wireMockServer.verify(1, RequestPatternBuilder.forCustomMatcher(noResultOffset.getRequest()));
+ wireMockRuntimeInfo.getWireMock().verifyThat(0, RequestPatternBuilder.forCustomMatcher(noConflation.getRequest()));
+ wireMockRuntimeInfo.getWireMock().verifyThat(0, RequestPatternBuilder.forCustomMatcher(resultOffset.getRequest()));
+ wireMockRuntimeInfo.getWireMock().verifyThat(1, RequestPatternBuilder.forCustomMatcher(noResultOffset.getRequest()));
}
}
diff --git a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/backend/DataConflationSenderTest.java b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/backend/DataConflationSenderTest.java
index f0fdc93b..84f3261f 100644
--- a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/backend/DataConflationSenderTest.java
+++ b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/backend/DataConflationSenderTest.java
@@ -9,6 +9,8 @@
import java.util.concurrent.TimeUnit;
import java.util.stream.Stream;
+import com.github.tomakehurst.wiremock.junit5.WireMockRuntimeInfo;
+import com.github.tomakehurst.wiremock.matching.RequestPatternBuilder;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.function.ThrowingSupplier;
@@ -46,9 +48,6 @@
@Wiremock
@MapWithAISources
class DataConflationSenderTest {
- @BasicWiremock
- WireMockServer wireMockServer;
-
static class MapWithAIConflationCategoryMock extends MockUp {
static String url;
@@ -81,10 +80,10 @@ void testEmptyUrl() {
}
@Test
- void testWorkingUrl() {
- MapWithAIConflationCategoryMock.url = wireMockServer.baseUrl() + "/conflate";
- final StubMapping stubMapping = wireMockServer
- .stubFor(WireMock.post("/conflate").willReturn(WireMock.aResponse().withBody(
+ void testWorkingUrl(WireMockRuntimeInfo wireMockRuntimeInfo) {
+ MapWithAIConflationCategoryMock.url = wireMockRuntimeInfo.getHttpBaseUrl() + "/conflate";
+ final StubMapping stubMapping = wireMockRuntimeInfo.getWireMock()
+ .register(WireMock.post("/conflate").willReturn(WireMock.aResponse().withBody(
"")));
new MapWithAIConflationCategoryMock();
@@ -99,14 +98,13 @@ void testWorkingUrl() {
assertEquals(1, conflated.getNodes().size());
final Node conflatedNode = conflated.getNodes().iterator().next();
assertEquals(new LatLon(89, 0.1), conflatedNode.getCoor());
- assertEquals(1, wireMockServer.getAllServeEvents().stream()
- .filter(serveEvent -> stubMapping.equals(serveEvent.getStubMapping())).count());
+ wireMockRuntimeInfo.getWireMock().verifyThat(1, RequestPatternBuilder.like(stubMapping.getRequest()));
}
@Test
- void testWorkingUrlTimeout() {
- MapWithAIConflationCategoryMock.url = wireMockServer.baseUrl() + "/conflate";
- final StubMapping stubMapping = wireMockServer.stubFor(WireMock.post("/conflate")
+ void testWorkingUrlTimeout(WireMockRuntimeInfo wireMockRuntimeInfo) {
+ MapWithAIConflationCategoryMock.url = wireMockRuntimeInfo.getHttpBaseUrl() + "/conflate";
+ final StubMapping stubMapping = wireMockRuntimeInfo.getWireMock().register(WireMock.post("/conflate")
.willReturn(WireMock.aResponse().withBody(
"")
.withFixedDelay(500)));
@@ -123,8 +121,7 @@ void testWorkingUrlTimeout() {
assertEquals(1, conflated.getNodes().size());
final Node conflatedNode = conflated.getNodes().iterator().next();
assertEquals(new LatLon(89, 0.1), conflatedNode.getCoor());
- assertEquals(1, wireMockServer.getAllServeEvents().stream()
- .filter(serveEvent -> stubMapping.equals(serveEvent.getStubMapping())).count());
+ wireMockRuntimeInfo.getWireMock().verifyThat(1, RequestPatternBuilder.like(stubMapping.getRequest()));
}
static Stream testNonWorkingUrl() {
@@ -135,9 +132,9 @@ static Stream testNonWorkingUrl() {
@ParameterizedTest
@MethodSource
- void testNonWorkingUrl(final ResponseDefinitionBuilder response) {
- MapWithAIConflationCategoryMock.url = wireMockServer.baseUrl() + "/conflate";
- final StubMapping stubMapping = wireMockServer.stubFor(WireMock.post("/conflate").willReturn(response));
+ void testNonWorkingUrl(final ResponseDefinitionBuilder response, final WireMockRuntimeInfo wireMockRuntimeInfo) {
+ MapWithAIConflationCategoryMock.url = wireMockRuntimeInfo.getHttpBaseUrl() + "/conflate";
+ final StubMapping stubMapping = wireMockRuntimeInfo.getWireMock().register(WireMock.post("/conflate").willReturn(response));
new MapWithAIConflationCategoryMock();
final DataSet external = new DataSet(new Node(LatLon.NORTH_POLE));
@@ -147,7 +144,6 @@ void testNonWorkingUrl(final ResponseDefinitionBuilder response) {
dataConflationSender.run();
final DataSet conflated = assertDoesNotThrow((ThrowingSupplier) dataConflationSender::get);
assertNull(conflated);
- assertEquals(1, wireMockServer.getAllServeEvents().stream()
- .filter(serveEvent -> stubMapping.equals(serveEvent.getStubMapping())).count());
+ wireMockRuntimeInfo.getWireMock().verifyThat(1, RequestPatternBuilder.like(stubMapping.getRequest()));
}
}
diff --git a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/io/mapwithai/ESRISourceReaderTest.java b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/io/mapwithai/ESRISourceReaderTest.java
index 5d073546..6aae0aae 100644
--- a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/io/mapwithai/ESRISourceReaderTest.java
+++ b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/io/mapwithai/ESRISourceReaderTest.java
@@ -12,6 +12,7 @@
import java.util.concurrent.Future;
import java.util.stream.Collectors;
+import com.github.tomakehurst.wiremock.junit5.WireMockRuntimeInfo;
import org.awaitility.Awaitility;
import org.awaitility.Durations;
import org.junit.jupiter.api.AfterEach;
@@ -31,9 +32,6 @@
@Wiremock
class ESRISourceReaderTest {
- @BasicWiremock
- public WireMockServer wireMockServer;
-
@BeforeEach
void setUp() {
ESRISourceReader.SOURCE_CACHE.clear();
@@ -51,11 +49,11 @@ void tearDown() {
* file/wiremocked file
*/
@Test
- void testAddEsriLayer() throws IOException {
+ void testAddEsriLayer(WireMockRuntimeInfo wireMockRuntimeInfo) throws IOException {
// TODO wiremock
MapWithAIInfo info = new MapWithAIInfo("TEST", "test_url", "bdf6c800b3ae453b9db239e03d7c1727");
info.setSourceType(MapWithAIType.ESRI);
- String tUrl = wireMockServer.url("/sharing/rest");
+ String tUrl = wireMockRuntimeInfo.getHttpBaseUrl() + "/sharing/rest";
for (String url : Arrays.asList(tUrl, tUrl + "/")) {
info.setUrl(url);
final ESRISourceReader reader = new ESRISourceReader(info);
@@ -65,7 +63,7 @@ void testAddEsriLayer() throws IOException {
} catch (ExecutionException | InterruptedException e) {
throw new JosmRuntimeException(e);
}
- }).collect(Collectors.toList());
+ }).toList();
Future> workerQueue = MainApplication.worker.submit(() -> {
/* Sync threads */});
Awaitility.await().atMost(Durations.FIVE_SECONDS).until(workerQueue::isDone);
diff --git a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/testutils/annotations/MapWithAIConfig.java b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/testutils/annotations/MapWithAIConfig.java
index bf38e4c9..e1234903 100644
--- a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/testutils/annotations/MapWithAIConfig.java
+++ b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/testutils/annotations/MapWithAIConfig.java
@@ -8,14 +8,13 @@
import java.lang.annotation.Target;
import java.util.stream.Stream;
+import com.github.tomakehurst.wiremock.junit5.WireMockRuntimeInfo;
import org.junit.jupiter.api.extension.AfterEachCallback;
import org.junit.jupiter.api.extension.BeforeEachCallback;
import org.junit.jupiter.api.extension.ExtendWith;
import org.junit.jupiter.api.extension.ExtensionContext;
import org.openstreetmap.josm.plugins.mapwithai.spi.preferences.IMapWithAIUrls;
-import com.github.tomakehurst.wiremock.WireMockServer;
-
/**
* Set the MapWithAI config for the test
*
@@ -29,7 +28,7 @@
public @interface MapWithAIConfig {
class MapWithAIConfigExtension extends Wiremock.WiremockExtension implements BeforeEachCallback, AfterEachCallback {
@Override
- public void beforeEach(ExtensionContext context) throws Exception {
+ public void beforeEach(ExtensionContext context) {
org.openstreetmap.josm.plugins.mapwithai.spi.preferences.MapWithAIConfig
.setUrlsProvider(new WireMockMapWithAIUrls(getWiremock(context)));
}
@@ -42,25 +41,25 @@ public void afterEach(ExtensionContext context) {
}
private static final class WireMockMapWithAIUrls implements IMapWithAIUrls {
- private final WireMockServer wireMockServer;
+ private final WireMockRuntimeInfo wireMockServer;
- public WireMockMapWithAIUrls(final WireMockServer wireMockServer) {
+ public WireMockMapWithAIUrls(final WireMockRuntimeInfo wireMockServer) {
this.wireMockServer = wireMockServer;
}
@Override
public String getConflationServerJson() {
- return this.wireMockServer.baseUrl() + "/MapWithAI/json/conflation_servers.json";
+ return this.wireMockServer.getHttpBaseUrl() + "/MapWithAI/json/conflation_servers.json";
}
@Override
public String getMapWithAISourcesJson() {
- return this.wireMockServer.baseUrl() + "/MapWithAI/json/sources.json";
+ return this.wireMockServer.getHttpBaseUrl() + "/MapWithAI/json/sources.json";
}
@Override
public String getMapWithAIPaintStyle() {
- return this.wireMockServer.baseUrl() + "/josmfile?page=Styles/MapWithAI&zip=1";
+ return this.wireMockServer.getHttpBaseUrl() + "/josmfile?page=Styles/MapWithAI&zip=1";
}
}
diff --git a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/testutils/annotations/Wiremock.java b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/testutils/annotations/Wiremock.java
index 88459e16..1a61ef06 100644
--- a/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/testutils/annotations/Wiremock.java
+++ b/src/test/unit/org/openstreetmap/josm/plugins/mapwithai/testutils/annotations/Wiremock.java
@@ -1,17 +1,29 @@
// License: GPL. For details, see LICENSE file.
package org.openstreetmap.josm.plugins.mapwithai.testutils.annotations;
+import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
+
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
+import java.lang.reflect.Field;
+import java.net.MalformedURLException;
+import java.net.URL;
import java.util.Optional;
import java.util.concurrent.atomic.AtomicBoolean;
+import com.github.tomakehurst.wiremock.junit5.WireMockRuntimeInfo;
import org.awaitility.Awaitility;
import org.awaitility.Durations;
+import org.junit.jupiter.api.extension.AfterAllCallback;
+import org.junit.jupiter.api.extension.AfterEachCallback;
+import org.junit.jupiter.api.extension.BeforeAllCallback;
+import org.junit.jupiter.api.extension.BeforeEachCallback;
import org.junit.jupiter.api.extension.ExtendWith;
import org.junit.jupiter.api.extension.ExtensionContext;
+import org.junit.jupiter.api.extension.ParameterContext;
+import org.junit.jupiter.api.extension.ParameterResolutionException;
import org.junit.platform.commons.support.AnnotationSupport;
import org.openstreetmap.josm.plugins.mapwithai.backend.DataAvailability;
import org.openstreetmap.josm.plugins.mapwithai.data.mapwithai.MapWithAIConflationCategory;
@@ -29,11 +41,8 @@
import com.github.tomakehurst.wiremock.WireMockServer;
import com.github.tomakehurst.wiremock.client.WireMock;
-import com.github.tomakehurst.wiremock.common.FileSource;
-import com.github.tomakehurst.wiremock.extension.Parameters;
-import com.github.tomakehurst.wiremock.extension.ResponseTransformer;
-import com.github.tomakehurst.wiremock.http.Request;
-import com.github.tomakehurst.wiremock.http.Response;
+import org.openstreetmap.josm.tools.Logging;
+import org.openstreetmap.josm.tools.ReflectionUtils;
/**
* Test annotation to ensure that wiremock is used
@@ -44,8 +53,8 @@
@Target({ ElementType.PARAMETER, ElementType.TYPE, ElementType.METHOD })
@BasicPreferences
@HTTP
+@BasicWiremock(value = "src/test/resources/wiremock")
@ExtendWith(Wiremock.TestMapWithAIUrls.class)
-@BasicWiremock(value = "src/test/resources/wiremock", responseTransformers = Wiremock.WireMockUrlTransformer.class)
public @interface Wiremock {
/**
* Set to {@code false} to turn off wiremock (use only in integration tests)
@@ -54,72 +63,35 @@
*/
boolean value() default true;
- /**
- * Replace URL's with the wiremock URL
- *
- * @author Taylor Smock
- */
- class WireMockUrlTransformer extends ResponseTransformer {
- private final ExtensionContext context;
-
- public WireMockUrlTransformer(ExtensionContext context) {
- this.context = context;
- }
-
- @Override
- public String getName() {
- return "Convert urls in responses to wiremock url";
- }
-
- @Override
- public Response transform(Request request, Response response, FileSource files, Parameters parameters) {
- if (!request.getUrl().endsWith("/capabilities")
- && response.getHeaders().getContentTypeHeader().mimeTypePart() != null
- && !response.getHeaders().getContentTypeHeader().mimeTypePart().contains("application/zip")) {
- String origBody = response.getBodyAsString();
- String newBody = origBody.replaceAll("https?://.*?/",
- WiremockExtension.getWiremock(context).baseUrl() + "/");
- return Response.Builder.like(response).but().body(newBody).build();
- }
- return response;
- }
- }
-
/**
* This is the base wiremock extension class
*/
- class WiremockExtension extends BasicWiremock.WireMockExtension {
+ class WiremockExtension {
/**
* Get the default wiremock server
*
* @param context The context to search
* @return The wiremock server
*/
- public static WireMockServer getWiremock(ExtensionContext context) {
- ExtensionContext.Namespace namespace = ExtensionContext.Namespace.create(BasicWiremock.class);
- return context.getStore(namespace).get(WireMockServer.class, WireMockServer.class);
+ public static WireMockRuntimeInfo getWiremock(ExtensionContext context) {
+ return context.getStore(ExtensionContext.Namespace.create(BasicWiremock.WireMockExtension.class))
+ .get(BasicWiremock.WireMockExtension.class, BasicWiremock.WireMockExtension.class)
+ .getRuntimeInfo();
}
}
/**
* Extension for {@link MapWithAILayerInfo}
*/
- class MapWithAILayerInfoExtension extends WiremockExtension {
- private static int hashCode;
+ class MapWithAILayerInfoExtension extends WiremockExtension implements BeforeAllCallback, AfterAllCallback {
@Override
- public void afterAll(ExtensionContext context) throws Exception {
- try {
- super.afterAll(context);
- } finally {
- resetMapWithAILayerInfo(context);
- }
+ public void afterAll(ExtensionContext context) {
+ resetMapWithAILayerInfo(context);
}
@Override
- public void beforeAll(ExtensionContext context) throws Exception {
- super.beforeAll(context);
-
+ public void beforeAll(ExtensionContext context) {
MapWithAILayerInfo.setImageryLayersSites(null);
AtomicBoolean finished = new AtomicBoolean();
MapWithAILayerInfo.getInstance().clear();
@@ -141,29 +113,45 @@ private static void resetMapWithAILayerInfo(ExtensionContext context) {
}
- class TestMapWithAIUrls extends WiremockExtension implements IMapWithAIUrls {
+ class TestMapWithAIUrls extends WiremockExtension implements IMapWithAIUrls, BeforeAllCallback, BeforeEachCallback, AfterAllCallback, AfterEachCallback {
ExtensionContext context;
private static boolean conflationServerInitialized;
+ /**
+ * Replace URL servers with wiremock
+ *
+ * @param baseUrl The wiremock to point to
+ * @param url The URL to fix
+ * @return A url that points at the wiremock server
+ */
+ public static String replaceUrl(String baseUrl, String url) {
+ try {
+ URL temp = new URL(url);
+ return baseUrl + temp.getFile();
+ } catch (MalformedURLException error) {
+ Logging.error(error);
+ }
+ return null;
+ }
+
@Override
public String getConflationServerJson() {
conflationServerInitialized = true;
- return replaceUrl(getWiremock(this.context), MapWithAIUrls.getInstance().getConflationServerJson());
+ return replaceUrl(getWiremock(this.context).getHttpBaseUrl(), MapWithAIUrls.getInstance().getConflationServerJson());
}
@Override
public String getMapWithAISourcesJson() {
- return replaceUrl(getWiremock(this.context), MapWithAIUrls.getInstance().getMapWithAISourcesJson());
+ return replaceUrl(getWiremock(this.context).getHttpBaseUrl(), MapWithAIUrls.getInstance().getMapWithAISourcesJson());
}
@Override
public String getMapWithAIPaintStyle() {
- return replaceUrl(getWiremock(this.context), MapWithAIUrls.getInstance().getMapWithAIPaintStyle());
+ return replaceUrl(getWiremock(this.context).getHttpBaseUrl(), MapWithAIUrls.getInstance().getMapWithAIPaintStyle());
}
@Override
- public void beforeAll(ExtensionContext context) throws Exception {
- super.beforeAll(context);
+ public void beforeAll(ExtensionContext context) {
final Optional annotation = AnnotationUtils.findFirstParentAnnotation(context, Wiremock.class);
this.context = context;
if (Boolean.FALSE.equals(annotation.map(Wiremock::value).orElse(Boolean.TRUE))) {
@@ -174,44 +162,48 @@ public void beforeAll(ExtensionContext context) throws Exception {
if (conflationServerInitialized) {
MapWithAIConflationCategory.initialize();
}
- AnnotationUtils.resetStaticClass(DataAvailability.class);
+ assertDoesNotThrow(() -> AnnotationUtils.resetStaticClass(DataAvailability.class));
}
@Override
- public void beforeEach(ExtensionContext context) throws Exception {
+ public void beforeEach(ExtensionContext context) {
final Optional annotation = AnnotationUtils.findFirstParentAnnotation(context, Wiremock.class);
this.context = context;
if (annotation.isPresent()) {
this.beforeAll(context);
}
- final WireMockServer wireMockServer = getWiremock(context);
-
- super.beforeEach(context);
+ final WireMock wireMockServer = getWiremock(context).getWireMock();
- if (wireMockServer.getStubMappings().stream().filter(mapping -> mapping.getRequest().getUrl() != null)
+ if (wireMockServer.allStubMappings().getMappings().stream().filter(mapping -> mapping.getRequest().getUrl() != null)
.noneMatch(mapping -> mapping.getRequest().getUrl()
.equals("/MapWithAI/json/conflation_servers.json"))) {
- wireMockServer.stubFor(WireMock.get("/MapWithAI/json/conflation_servers.json")
+ wireMockServer.register(WireMock.get("/MapWithAI/json/conflation_servers.json")
.willReturn(WireMock.aResponse().withBody("{}")).atPriority(-5));
}
}
@Override
- public void afterAll(ExtensionContext context) throws Exception {
+ public void afterEach(ExtensionContext extensionContext) {
+ this.context = extensionContext;
+ }
+
+ @Override
+ public void afterAll(ExtensionContext context) {
+ this.context = context;
// @Wiremock stops the WireMockServer prior to this method being called
- getWiremock(context).start();
- MapPaintUtils.removeMapWithAIPaintStyles();
+ final WireMockServer wireMockServer = assertDoesNotThrow(() -> {
+ final Field serverField = WireMockRuntimeInfo.class.getDeclaredField("wireMockServer");
+ ReflectionUtils.setObjectsAccessible(serverField);
+ return (WireMockServer) serverField.get(getWiremock(context));
+ });
try {
- // This stops the WireMockServer again.
- super.afterAll(context);
+ wireMockServer.start();
+ MapPaintUtils.removeMapWithAIPaintStyles();
+ wireMockServer.stop();
} finally {
MapWithAIConfig.setUrlsProvider(new InvalidMapWithAIUrls());
}
}
-
- public WireMockServer getWireMockServer() {
- return getWiremock(context);
- }
}
class InvalidMapWithAIUrls implements IMapWithAIUrls {