package redis.clients.jedis.tests.commands;
import org.junit.Test;
import redis.clients.jedis.GeoCoordinate;
import redis.clients.jedis.GeoRadiusResponse;
import redis.clients.jedis.GeoUnit;
import redis.clients.jedis.params.geo.GeoRadiusParam;
import redis.clients.util.SafeEncoder;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class GeoCommandsTest extends JedisCommandTestBase {
final byte[] bfoo = { 0x01, 0x02, 0x03, 0x04 };
final byte[] bA = { 0x0A };
final byte[] bB = { 0x0B };
final byte[] bC = { 0x0C };
final byte[] bD = { 0x0D };
final byte[] bNotexist = { 0x0F };
@Test
public void geoadd() {
long size = jedis.geoadd("foo", 1, 2, "a");
assertEquals(1, size);
size = jedis.geoadd("foo", 2, 3, "a");
assertEquals(0, size);
Map<String, GeoCoordinate> coordinateMap = new HashMap<String, GeoCoordinate>();
coordinateMap.put("a", new GeoCoordinate(3, 4));
coordinateMap.put("b", new GeoCoordinate(2, 3));
coordinateMap.put("c", new GeoCoordinate(3.314, 2.3241));
size = jedis.geoadd("foo", coordinateMap);
assertEquals(2, size);
// binary
size = jedis.geoadd(bfoo, 1, 2, bA);
assertEquals(1, size);
size = jedis.geoadd(bfoo, 2, 3, bA);
assertEquals(0, size);
Map<byte[], GeoCoordinate> bcoordinateMap = new HashMap<byte[], GeoCoordinate>();
bcoordinateMap.put(bA, new GeoCoordinate(3, 4));
bcoordinateMap.put(bB, new GeoCoordinate(2, 3));
bcoordinateMap.put(bC, new GeoCoordinate(3.314, 2.3241));
size = jedis.geoadd(bfoo, bcoordinateMap);
assertEquals(2, size);
}
@Test
public void geodist() {
prepareGeoData();
Double dist = jedis.geodist("foo", "a", "b");
assertEquals(dist.intValue(), 157149);
dist = jedis.geodist("foo", "a", "b", GeoUnit.KM);
assertEquals(dist.intValue(), 157);
dist = jedis.geodist("foo", "a", "b", GeoUnit.MI);
assertEquals(dist.intValue(), 97);
dist = jedis.geodist("foo", "a", "b", GeoUnit.FT);
assertEquals(dist.intValue(), 515583);
// binary
dist = jedis.geodist(bfoo, bA, bB);
assertEquals(dist.intValue(), 157149);
dist = jedis.geodist(bfoo, bA, bB, GeoUnit.KM);
assertEquals(dist.intValue(), 157);
dist = jedis.geodist(bfoo, bA, bB, GeoUnit.MI);
assertEquals(dist.intValue(), 97);
dist = jedis.geodist(bfoo, bA, bB, GeoUnit.FT);
assertEquals(dist.intValue(), 515583);
}
@Test
public void geohash() {
prepareGeoData();
List<String> hashes = jedis.geohash("foo", "a", "b", "notexist");
assertEquals(3, hashes.size());
assertEquals("s0dnu20t9j0", hashes.get(0));
assertEquals("s093jd0k720", hashes.get(1));
assertNull(hashes.get(2));
// binary
List<byte[]> bhashes = jedis.geohash(bfoo, bA, bB, bNotexist);
assertEquals(3, bhashes.size());
assertArrayEquals(SafeEncoder.encode("s0dnu20t9j0"), bhashes.get(0));
assertArrayEquals(SafeEncoder.encode("s093jd0k720"), bhashes.get(1));
assertNull(bhashes.get(2));
}
@Test
public void geopos() {
prepareGeoData();
List<GeoCoordinate> coordinates = jedis.geopos("foo", "a", "b", "notexist");
assertEquals(3, coordinates.size());
assertTrue(equalsWithinEpsilon(3.0, coordinates.get(0).getLongitude()));
assertTrue(equalsWithinEpsilon(4.0, coordinates.get(0).getLatitude()));
assertTrue(equalsWithinEpsilon(2.0, coordinates.get(1).getLongitude()));
assertTrue(equalsWithinEpsilon(3.0, coordinates.get(1).getLatitude()));
assertNull(coordinates.get(2));
List<GeoCoordinate> bcoordinates = jedis.geopos(bfoo, bA, bB, bNotexist);
assertEquals(3, bcoordinates.size());
assertTrue(equalsWithinEpsilon(3.0, bcoordinates.get(0).getLongitude()));
assertTrue(equalsWithinEpsilon(4.0, bcoordinates.get(0).getLatitude()));
assertTrue(equalsWithinEpsilon(2.0, bcoordinates.get(1).getLongitude()));
assertTrue(equalsWithinEpsilon(3.0, bcoordinates.get(1).getLatitude()));
assertNull(bcoordinates.get(2));
}
@Test
public void georadius() {
// prepare datas
Map<String, GeoCoordinate> coordinateMap = new HashMap<String, GeoCoordinate>();
coordinateMap.put("Palermo", new GeoCoordinate(13.361389, 38.115556));
coordinateMap.put("Catania", new GeoCoordinate(15.087269, 37.502669));
jedis.geoadd("Sicily", coordinateMap);
List<GeoRadiusResponse> members = jedis.georadius("Sicily", 15, 37, 200, GeoUnit.KM);
assertEquals(2, members.size());
// sort
members = jedis.georadius("Sicily", 15, 37, 200, GeoUnit.KM, GeoRadiusParam.geoRadiusParam()
.sortAscending());
assertEquals(2, members.size());
assertEquals("Catania", members.get(0).getMemberByString());
assertEquals("Palermo", members.get(1).getMemberByString());
// sort, count 1
members = jedis.georadius("Sicily", 15, 37, 200, GeoUnit.KM, GeoRadiusParam.geoRadiusParam()
.sortAscending().count(1));
assertEquals(1, members.size());
// sort, count 1, withdist, withcoord
members = jedis.georadius("Sicily", 15, 37, 200, GeoUnit.KM, GeoRadiusParam.geoRadiusParam()
.sortAscending().count(1).withCoord().withDist());
assertEquals(1, members.size());
GeoRadiusResponse response = members.get(0);
assertTrue(equalsWithinEpsilon(56.4413, response.getDistance()));
assertTrue(equalsWithinEpsilon(15.087269, response.getCoordinate().getLongitude()));
assertTrue(equalsWithinEpsilon(37.502669, response.getCoordinate().getLatitude()));
}
@Test
public void georadiusBinary() {
// prepare datas
Map<byte[], GeoCoordinate> bcoordinateMap = new HashMap<byte[], GeoCoordinate>();
bcoordinateMap.put(bA, new GeoCoordinate(13.361389, 38.115556));
bcoordinateMap.put(bB, new GeoCoordinate(15.087269, 37.502669));
jedis.geoadd(bfoo, bcoordinateMap);
List<GeoRadiusResponse> members = jedis.georadius(bfoo, 15, 37, 200, GeoUnit.KM);
assertEquals(2, members.size());
// sort
members = jedis.georadius(bfoo, 15, 37, 200, GeoUnit.KM, GeoRadiusParam.geoRadiusParam()
.sortAscending());
assertEquals(2, members.size());
assertArrayEquals(bB, members.get(0).getMember());
assertArrayEquals(bA, members.get(1).getMember());
// sort, count 1
members = jedis.georadius(bfoo, 15, 37, 200, GeoUnit.KM, GeoRadiusParam.geoRadiusParam()
.sortAscending().count(1));
assertEquals(1, members.size());
// sort, count 1, withdist, withcoord
members = jedis.georadius(bfoo, 15, 37, 200, GeoUnit.KM, GeoRadiusParam.geoRadiusParam()
.sortAscending().count(1).withCoord().withDist());
assertEquals(1, members.size());
GeoRadiusResponse response = members.get(0);
assertTrue(equalsWithinEpsilon(56.4413, response.getDistance()));
assertTrue(equalsWithinEpsilon(15.087269, response.getCoordinate().getLongitude()));
assertTrue(equalsWithinEpsilon(37.502669, response.getCoordinate().getLatitude()));
}
@Test
public void georadiusByMember() {
jedis.geoadd("Sicily", 13.583333, 37.316667, "Agrigento");
jedis.geoadd("Sicily", 13.361389, 38.115556, "Palermo");
jedis.geoadd("Sicily", 15.087269, 37.502669, "Catania");
List<GeoRadiusResponse> members = jedis.georadiusByMember("Sicily", "Agrigento", 100,
GeoUnit.KM);
assertEquals(2, members.size());
members = jedis.georadiusByMember("Sicily", "Agrigento", 100, GeoUnit.KM, GeoRadiusParam
.geoRadiusParam().sortAscending());
assertEquals(2, members.size());
assertEquals("Agrigento", members.get(0).getMemberByString());
assertEquals("Palermo", members.get(1).getMemberByString());
members = jedis.georadiusByMember("Sicily", "Agrigento", 100, GeoUnit.KM, GeoRadiusParam
.geoRadiusParam().sortAscending().count(1).withCoord().withDist());
assertEquals(1, members.size());
GeoRadiusResponse member = members.get(0);
assertEquals("Agrigento", member.getMemberByString());
assertTrue(equalsWithinEpsilon(0, member.getDistance()));
assertTrue(equalsWithinEpsilon(13.583333, member.getCoordinate().getLongitude()));
assertTrue(equalsWithinEpsilon(37.316667, member.getCoordinate().getLatitude()));
}
@Test
public void georadiusByMemberBinary() {
jedis.geoadd(bfoo, 13.583333, 37.316667, bA);
jedis.geoadd(bfoo, 13.361389, 38.115556, bB);
jedis.geoadd(bfoo, 15.087269, 37.502669, bC);
List<GeoRadiusResponse> members = jedis.georadiusByMember(bfoo, bA, 100, GeoUnit.KM);
assertEquals(2, members.size());
members = jedis.georadiusByMember(bfoo, bA, 100, GeoUnit.KM, GeoRadiusParam.geoRadiusParam()
.sortAscending());
assertEquals(2, members.size());
assertArrayEquals(bA, members.get(0).getMember());
assertArrayEquals(bB, members.get(1).getMember());
members = jedis.georadiusByMember(bfoo, bA, 100, GeoUnit.KM, GeoRadiusParam.geoRadiusParam()
.sortAscending().count(1).withCoord().withDist());
assertEquals(1, members.size());
GeoRadiusResponse member = members.get(0);
assertArrayEquals(bA, member.getMember());
assertTrue(equalsWithinEpsilon(0, member.getDistance()));
assertTrue(equalsWithinEpsilon(13.583333, member.getCoordinate().getLongitude()));
assertTrue(equalsWithinEpsilon(37.316667, member.getCoordinate().getLatitude()));
}
private void prepareGeoData() {
Map<String, GeoCoordinate> coordinateMap = new HashMap<String, GeoCoordinate>();
coordinateMap.put("a", new GeoCoordinate(3, 4));
coordinateMap.put("b", new GeoCoordinate(2, 3));
coordinateMap.put("c", new GeoCoordinate(3.314, 2.3241));
long size = jedis.geoadd("foo", coordinateMap);
assertEquals(3, size);
Map<byte[], GeoCoordinate> bcoordinateMap = new HashMap<byte[], GeoCoordinate>();
bcoordinateMap.put(bA, new GeoCoordinate(3, 4));
bcoordinateMap.put(bB, new GeoCoordinate(2, 3));
bcoordinateMap.put(bC, new GeoCoordinate(3.314, 2.3241));
size = jedis.geoadd(bfoo, bcoordinateMap);
assertEquals(3, size);
}
private boolean equalsWithinEpsilon(double d1, double d2) {
double epsilon = 1E-5;
return Math.abs(d1 - d2) < epsilon;
}
}