aboutsummaryrefslogtreecommitdiffstats
path: root/tests/src/cgeo
diff options
context:
space:
mode:
authorBananeweizen <bananeweizen@gmx.de>2015-01-26 20:55:25 +0100
committerBananeweizen <bananeweizen@gmx.de>2015-01-26 20:55:25 +0100
commit0f0fd3e75d6cfeffd8ba0a3e26e269b0db2b17c7 (patch)
tree87c78df09128b262e13634a88926aa129dbcd088 /tests/src/cgeo
parent90bf6cf84dbda53c6a7c1e28545e8e531bd7d13b (diff)
downloadcgeo-0f0fd3e75d6cfeffd8ba0a3e26e269b0db2b17c7.zip
cgeo-0f0fd3e75d6cfeffd8ba0a3e26e269b0db2b17c7.tar.gz
cgeo-0f0fd3e75d6cfeffd8ba0a3e26e269b0db2b17c7.tar.bz2
GPX export test doesn't recognize failure
We exported empty GPX file from that test. Therefore verify they actually contain the cache.
Diffstat (limited to 'tests/src/cgeo')
-rw-r--r--tests/src/cgeo/geocaching/export/ExportTest.java19
1 files changed, 16 insertions, 3 deletions
diff --git a/tests/src/cgeo/geocaching/export/ExportTest.java b/tests/src/cgeo/geocaching/export/ExportTest.java
index 965abdd..edbf413 100644
--- a/tests/src/cgeo/geocaching/export/ExportTest.java
+++ b/tests/src/cgeo/geocaching/export/ExportTest.java
@@ -12,6 +12,7 @@ import cgeo.geocaching.location.Geopoint;
import cgeo.geocaching.utils.FileUtils;
import java.io.File;
+import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
@@ -28,15 +29,22 @@ public class ExportTest extends CGeoTestCase {
assertEquals("Non matching export " + fieldNotes.getContent(), "GCX1234,2012-11-18T13:20:20Z,Found it,\"Hidden in a tree\"\n", fieldNotes.getContent());
}
- public static void testGpxExportSmilies() throws InterruptedException, ExecutionException {
+ public static void testGpxExportSmilies() throws InterruptedException, ExecutionException, IOException {
final Geocache cache = new Geocache();
cache.setGeocode("GCX1234");
cache.setCoords(new Geopoint("N 49 44.000 E 8 37.000"));
final LogEntry log = new LogEntry(1353244820000L, LogType.FOUND_IT, "Smile: \ud83d\ude0a");
DataStore.saveCache(cache, LoadFlags.SAVE_ALL);
DataStore.saveLogs(cache.getGeocode(), Collections.singletonList(log));
- ArrayList<Geocache> exportList = new ArrayList<Geocache>();
- exportList.add(cache);
+ assertCanExport(cache);
+ }
+
+ private static void assertCanExport(final Geocache cache) throws InterruptedException, ExecutionException, IOException {
+ // enforce storing in database, as GPX will not take information from cache
+ cache.setDetailed(true);
+ DataStore.saveCache(cache, LoadFlags.SAVE_ALL);
+
+ List<Geocache> exportList = Collections.singletonList(cache);
GpxExportTester gpxExport = new GpxExportTester();
File result = null;
try {
@@ -47,6 +55,11 @@ public class ExportTest extends CGeoTestCase {
assertThat(result).isNotNull();
+ // make sure we actually exported waypoints
+ String gpx = org.apache.commons.io.FileUtils.readFileToString(result);
+ assertThat(gpx).contains("<wpt");
+ assertThat(gpx).contains(cache.getGeocode());
+
FileUtils.deleteIgnoringFailure(result);
}