use of org.codice.ddf.spatial.geocoding.GeoEntryIndexingException in project ddf by codice.
the class TestGeoNamesUpdateCommand method testProgressOutput.
@Test
public void testProgressOutput() throws IOException {
final GeoEntryExtractor geoEntryExtractor = spy(new GeoEntryExtractor() {
@Override
public List<GeoEntry> getGeoEntries(final String resource, final ProgressCallback progressCallback) {
return null;
}
@Override
public void pushGeoEntriesToExtractionCallback(final String resource, final ExtractionCallback extractionCallback) {
extractionCallback.updateProgress(50);
assertThat(consoleInterceptor.getOutput(), containsString("50%"));
extractionCallback.updateProgress(100);
assertThat(consoleInterceptor.getOutput(), containsString("100%"));
}
@Override
public void setUrl(String url) {
return;
}
});
final GeoEntryExtractor geoEntryUrlExtractor = spy(new GeoEntryExtractor() {
@Override
public List<GeoEntry> getGeoEntries(final String resource, final ProgressCallback progressCallback) {
return null;
}
@Override
public void pushGeoEntriesToExtractionCallback(final String resource, final ExtractionCallback extractionCallback) {
extractionCallback.updateProgress(50);
assertThat(consoleInterceptor.getOutput(), containsString("50%"));
extractionCallback.updateProgress(100);
assertThat(consoleInterceptor.getOutput(), containsString("100%"));
}
@Override
public void setUrl(String url) {
return;
}
});
final GeoEntryIndexer geoEntryIndexer = spy(new GeoEntryIndexer() {
@Override
public void updateIndex(final List<GeoEntry> newEntries, final boolean create, final ProgressCallback progressCallback) {
}
@Override
public void updateIndex(final String resource, final GeoEntryExtractor geoEntryExtractor, final boolean create, final ProgressCallback progressCallback) throws GeoNamesRemoteDownloadException, GeoEntryIndexingException, GeoEntryExtractionException {
final ExtractionCallback extractionCallback = new ExtractionCallback() {
@Override
public void extracted(final GeoEntry newEntry) {
}
@Override
public void updateProgress(final int progress) {
progressCallback.updateProgress(progress);
}
};
geoEntryExtractor.pushGeoEntriesToExtractionCallback(resource, extractionCallback);
}
});
List<GeoEntryExtractor> geoEntryExtractors = new ArrayList<GeoEntryExtractor>();
geoEntryExtractors.add(geoEntryExtractor);
geoEntryExtractors.add(geoEntryUrlExtractor);
geoNamesUpdateCommand.setGeoEntryExtractor(geoEntryExtractor);
geoNamesUpdateCommand.setGeoEntryIndexer(geoEntryIndexer);
geoNamesUpdateCommand.setResource("test");
geoNamesUpdateCommand.execute();
consoleInterceptor.resetSystemOut();
consoleInterceptor.closeBuffer();
}
use of org.codice.ddf.spatial.geocoding.GeoEntryIndexingException in project ddf by codice.
the class TestGeoNamesLuceneIndexer method testCreateIndexFromExtractor.
@Test
public void testCreateIndexFromExtractor() throws IOException, GeoEntryIndexingException, GeoNamesRemoteDownloadException, GeoEntryExtractionException {
configureMocks();
final ProgressCallback progressCallback = mock(ProgressCallback.class);
geoNamesLuceneIndexer.updateIndex(null, new GeoEntryExtractor() {
@Override
public List<GeoEntry> getGeoEntries(final String resource, final ProgressCallback progressCallback) {
return null;
}
@Override
public void pushGeoEntriesToExtractionCallback(final String resource, final ExtractionCallback extractionCallback) throws GeoEntryExtractionException {
try {
extractionCallback.extracted(GEO_ENTRY_1);
extractionCallback.extracted(GEO_ENTRY_2);
extractionCallback.extracted(GEO_ENTRY_3);
extractionCallback.extracted(GEO_ENTRY_4);
extractionCallback.extracted(GEO_ENTRY_5);
extractionCallback.extracted(GEO_ENTRY_6);
extractionCallback.extracted(GEO_ENTRY_7);
extractionCallback.extracted(GEO_ENTRY_8);
extractionCallback.extracted(GEO_ENTRY_9);
extractionCallback.updateProgress(100);
} catch (GeoEntryIndexingException e) {
throw new GeoEntryExtractionException("Unable to add entry.", e);
}
}
@Override
public void setUrl(String url) {
return;
}
}, true, progressCallback);
verify(indexWriter, times(9)).addDocument(documentArgumentCaptor.capture());
final List<Document> documentList = documentArgumentCaptor.getAllValues();
verifyDocumentList(documentList);
verify(progressCallback, times(1)).updateProgress(100);
}
use of org.codice.ddf.spatial.geocoding.GeoEntryIndexingException in project ddf by codice.
the class GeoNamesLuceneIndexer method updateIndex.
@Override
public void updateIndex(final String resource, final GeoEntryExtractor geoEntryExtractor, final boolean create, final ProgressCallback progressCallback) throws GeoEntryIndexingException, GeoEntryExtractionException, GeoNamesRemoteDownloadException {
Directory directory;
try {
directory = FSDirectory.open(Paths.get(indexLocation));
} catch (IOException e) {
throw new GeoEntryIndexingException("Couldn't open the directory for the index, " + indexLocation, e);
}
// Try-with-resources to ensure the IndexWriter always gets closed.
try (final IndexWriter indexWriter = createIndexWriter(create, directory)) {
final SpatialPrefixTree grid = new GeohashPrefixTree(SPATIAL_CONTEXT, GeoNamesLuceneConstants.GEOHASH_LEVELS);
final SpatialStrategy strategy = new RecursivePrefixTreeStrategy(grid, GeoNamesLuceneConstants.GEO_FIELD);
final ExtractionCallback extractionCallback = new ExtractionCallback() {
@Override
public void extracted(final GeoEntry newEntry) throws GeoEntryIndexingException {
try {
addDocument(indexWriter, newEntry, strategy);
} catch (IOException e) {
throw new GeoEntryIndexingException("Error writing to the index.", e);
}
}
@Override
public void updateProgress(final int progress) {
if (progressCallback != null) {
progressCallback.updateProgress(progress);
}
}
};
try {
geoEntryExtractor.pushGeoEntriesToExtractionCallback(resource, extractionCallback);
} catch (GeoEntryExtractionException e) {
// Need to roll back here before the IndexWriter is closed at the end of the try
// block.
indexWriter.rollback();
throw e;
}
} catch (IOException e) {
throw new GeoEntryIndexingException("Error writing to the index.", e);
}
}
Aggregations