use of de.westnordost.osmapi.map.data.BoundingBox in project StreetComplete by westnordost.
the class OsmQuestDownloadTest method testIgnoreBlacklistedPositionsAndInvalidGeometry.
public void testIgnoreBlacklistedPositionsAndInvalidGeometry() {
LatLon blacklistPos = new OsmLatLon(3.0, 4.0);
ElementWithGeometry blacklistElement = new ElementWithGeometry();
blacklistElement.element = new OsmNode(0, 0, blacklistPos, null);
blacklistElement.geometry = new ElementGeometry(blacklistPos);
ElementWithGeometry invalidGeometryElement = new ElementWithGeometry();
invalidGeometryElement.element = new OsmNode(0, 0, new OsmLatLon(1.0, 1.0), null);
invalidGeometryElement.geometry = null;
OsmElementQuestType questType = new ListBackedQuestType(Arrays.asList(blacklistElement, invalidGeometryElement));
setUpOsmQuestDaoMockWithNoPreviousElements();
OsmQuestDownload dl = new OsmQuestDownload(geometryDb, elementDb, osmQuestDao, countryBoundariesFuture);
VisibleQuestListener listener = mock(VisibleQuestListener.class);
dl.setQuestListener(listener);
dl.download(questType, new BoundingBox(0, 0, 1, 1), Collections.singleton(blacklistPos));
verify(listener, times(0)).onQuestsCreated(any(Collection.class), any(QuestGroup.class));
}
use of de.westnordost.osmapi.map.data.BoundingBox in project StreetComplete by westnordost.
the class FiltersParserTest method testBoundingBoxWithMultipleElementTypes.
public void testBoundingBoxWithMultipleElementTypes() {
BoundingBox bbox = new BoundingBox(0, 0, 5, 10);
check("nodes, ways, relations", "[bbox:0.0,0.0,5.0,10.0];(node;way;rel;);out meta geom;", bbox);
check("nodes, ways, relations with highway", "[bbox:0.0,0.0,5.0,10.0];(" + "node[\"highway\"];" + "way[\"highway\"];" + "rel[\"highway\"];" + ");" + "out meta geom;", bbox);
check("nodes, ways, relations with highway or railway", "[bbox:0.0,0.0,5.0,10.0];(" + "node[\"highway\"];" + "node[\"railway\"];" + "way[\"highway\"];" + "way[\"railway\"];" + "rel[\"highway\"];" + "rel[\"railway\"];" + ");" + "out meta geom;", bbox);
}
use of de.westnordost.osmapi.map.data.BoundingBox in project StreetComplete by westnordost.
the class OsmNotesDownloadTest method testDeleteObsoleteQuests.
public void testDeleteObsoleteQuests() {
when(preferences.getBoolean(Prefs.SHOW_NOTES_NOT_PHRASED_AS_QUESTIONS, false)).thenReturn(true);
// in the quest database mock, there are quests for note 4 and note 5
List<OsmNoteQuest> quests = new ArrayList<>();
Note note1 = createANote();
note1.id = 4L;
quests.add(new OsmNoteQuest(12L, note1, QuestStatus.NEW, null, new Date(), new OsmNoteQuestType(), null));
Note note2 = createANote();
note2.id = 5L;
quests.add(new OsmNoteQuest(13L, note2, QuestStatus.NEW, null, new Date(), new OsmNoteQuestType(), null));
when(noteQuestDB.getAll(any(BoundingBox.class), any(QuestStatus.class))).thenReturn(quests);
doAnswer(invocation -> {
Collection<Long> deletedQuests = (Collection<Long>) (invocation.getArguments()[0]);
assertEquals(1, deletedQuests.size());
assertEquals(13L, (long) deletedQuests.iterator().next());
return 1;
}).when(noteQuestDB).deleteAll(any(Collection.class));
// note dao mock will only "find" the note #4
List<Note> notes = new ArrayList<>();
notes.add(note1);
NotesDao noteServer = new TestListBasedNotesDao(notes);
OsmNotesDownload dl = new OsmNotesDownload(noteServer, noteDB, noteQuestDB, createNoteDB, preferences, new OsmNoteQuestType());
VisibleQuestListener listener = mock(VisibleQuestListener.class);
dl.setQuestListener(listener);
dl.download(new BoundingBox(0, 0, 1, 1), null, 1000);
verify(noteQuestDB).deleteAll(any(Collection.class));
verify(listener).onQuestsRemoved(any(Collection.class), any(QuestGroup.class));
}
use of de.westnordost.osmapi.map.data.BoundingBox in project StreetComplete by westnordost.
the class SphericalEarthMathTest method testEnclosingBoundingBox.
public void testEnclosingBoundingBox() {
LatLon pos = new OsmLatLon(0, 0);
BoundingBox bbox = SphericalEarthMath.enclosingBoundingBox(pos, 5000);
int dist = (int) (Math.sqrt(2) * 5000);
// all four corners of the bbox should be 'radius' away
assertEquals(dist, Math.round(SphericalEarthMath.distance(pos, bbox.getMin())));
assertEquals(dist, Math.round(SphericalEarthMath.distance(pos, bbox.getMax())));
assertEquals(dist, Math.round(SphericalEarthMath.distance(pos, new OsmLatLon(bbox.getMinLatitude(), bbox.getMaxLongitude()))));
assertEquals(dist, Math.round(SphericalEarthMath.distance(pos, new OsmLatLon(bbox.getMaxLatitude(), bbox.getMinLongitude()))));
assertEquals(225, Math.round(SphericalEarthMath.bearing(pos, bbox.getMin())));
assertEquals(45, Math.round(SphericalEarthMath.bearing(pos, bbox.getMax())));
}
use of de.westnordost.osmapi.map.data.BoundingBox in project StreetComplete by westnordost.
the class SlippyMapMathTest method testForthAndBack.
public void testForthAndBack() {
LatLon p = new OsmLatLon(53.0, 9.0);
Point tile = SlippyMapMath.enclosingTile(p, 15);
BoundingBox bbox = SlippyMapMath.asBoundingBox(tile, 15);
assertTrue(bbox.getMinLatitude() <= p.getLatitude());
assertTrue(bbox.getMaxLatitude() >= p.getLatitude());
assertTrue(bbox.getMinLongitude() <= p.getLongitude());
assertTrue(bbox.getMaxLongitude() >= p.getLongitude());
Rect r = SlippyMapMath.enclosingTiles(bbox, 15);
BoundingBox bbox2 = SlippyMapMath.asBoundingBox(r, 15);
assertEquals(bbox, bbox2);
}
Aggregations