diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2016-12-31 11:35:58 +1300 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2016-12-31 11:35:58 +1300 |
commit | 68569c05fb4be377baed5cd0ecb1b75176d24f01 (patch) | |
tree | 2b50b96a047e8626d33121c7e6fcd0a102f61c77 /test/org/traccar/geocoder/ReverseGeocoderTest.java | |
parent | e8cd15c0fb192f635808adfde4e8614e6b4b3c3f (diff) | |
download | trackermap-server-68569c05fb4be377baed5cd0ecb1b75176d24f01.tar.gz trackermap-server-68569c05fb4be377baed5cd0ecb1b75176d24f01.tar.bz2 trackermap-server-68569c05fb4be377baed5cd0ecb1b75176d24f01.zip |
Rename geocode package to geocoder
Diffstat (limited to 'test/org/traccar/geocoder/ReverseGeocoderTest.java')
-rw-r--r-- | test/org/traccar/geocoder/ReverseGeocoderTest.java | 114 |
1 files changed, 114 insertions, 0 deletions
diff --git a/test/org/traccar/geocoder/ReverseGeocoderTest.java b/test/org/traccar/geocoder/ReverseGeocoderTest.java new file mode 100644 index 000000000..73753c96c --- /dev/null +++ b/test/org/traccar/geocoder/ReverseGeocoderTest.java @@ -0,0 +1,114 @@ +package org.traccar.geocoder; + +import org.junit.Assert; +import org.junit.Test; + +public class ReverseGeocoderTest { + + private boolean enable = false; + + @Test + public void test() throws InterruptedException { + if (enable) { + testGeocodeFarm(); + } + } + + private String address; + + private synchronized String waitAddress() { + try { + wait(5000); + return address; + } catch (InterruptedException e) { + throw new RuntimeException(e); + } + } + + private synchronized void setAddress(String address) { + this.address = address; + notifyAll(); + } + + public void testGoogle() throws InterruptedException { + ReverseGeocoder reverseGeocoder = new GoogleReverseGeocoder(); + + reverseGeocoder.getAddress(new AddressFormat(), 37.4217550, -122.0846330, new ReverseGeocoder.ReverseGeocoderCallback() { + @Override + public void onSuccess(String address) { + setAddress(address); + } + + @Override + public void onFailure(Throwable e) { + } + }); + Assert.assertEquals("1600 Amphitheatre Pkwy, Mountain View, CA, US", waitAddress()); + } + + public void testNominatim() throws InterruptedException { + ReverseGeocoder reverseGeocoder = new NominatimReverseGeocoder(); + + reverseGeocoder.getAddress(new AddressFormat(), 40.7337807, -73.9974401, new ReverseGeocoder.ReverseGeocoderCallback() { + @Override + public void onSuccess(String address) { + setAddress(address); + } + + @Override + public void onFailure(Throwable e) { + } + }); + Assert.assertEquals("35 West 9th Street, NYC, New York, US", waitAddress()); + } + + public void testGisgraphy() throws InterruptedException { + ReverseGeocoder reverseGeocoder = new GisgraphyReverseGeocoder(); + + reverseGeocoder.getAddress(new AddressFormat(), 48.8530000, 2.3400000, new ReverseGeocoder.ReverseGeocoderCallback() { + @Override + public void onSuccess(String address) { + setAddress(address); + } + + @Override + public void onFailure(Throwable e) { + } + }); + Assert.assertEquals("Rue du Jardinet, Paris, FR", waitAddress()); + } + + public void testOpenCage() throws InterruptedException { + ReverseGeocoder reverseGeocoder = new OpenCageReverseGeocoder( + "http://api.opencagedata.com/geocode/v1", "SECRET", 0); + + reverseGeocoder.getAddress(new AddressFormat(), 34.116302, -118.051519, new ReverseGeocoder.ReverseGeocoderCallback() { + @Override + public void onSuccess(String address) { + setAddress(address); + } + + @Override + public void onFailure(Throwable e) { + } + }); + Assert.assertEquals("Charleston Road, California, US", waitAddress()); + } + + public void testGeocodeFarm() throws InterruptedException { + ReverseGeocoder reverseGeocoder = new GeocodeFarmReverseGeocoder(0); + + reverseGeocoder.getAddress(new AddressFormat(), 34.116302, -118.051519, new ReverseGeocoder.ReverseGeocoderCallback() { + @Override + public void onSuccess(String address) { + setAddress(address); + } + + @Override + public void onFailure(Throwable e) { + } + }); + Assert.assertEquals("Estrella Avenue, Arcadia, California, United States", waitAddress()); + } + +} |