[Groonga-commit] groonga/grnxx at 694761d [master] Add a test for GeoPoint. (#99)

Back to archive index

susumu.yata null+****@clear*****
Tue Dec 16 10:42:03 JST 2014


susumu.yata	2014-11-07 14:18:56 +0900 (Fri, 07 Nov 2014)

  New Revision: 694761d2155e4163a501237bcb189ce74a4ccb6f
  https://github.com/groonga/grnxx/commit/694761d2155e4163a501237bcb189ce74a4ccb6f

  Message:
    Add a test for GeoPoint. (#99)

  Modified files:
    test/test_data_types.cpp

  Modified: test/test_data_types.cpp (+73 -1)
===================================================================
--- test/test_data_types.cpp    2014-11-07 13:51:57 +0900 (de5eee4)
+++ test/test_data_types.cpp    2014-11-07 14:18:56 +0900 (f17362f)
@@ -739,7 +739,79 @@ void test_float() {
 }
 
 void test_geo_point() {
-  // TODO
+  grnxx::GeoPoint zero(grnxx::Int(0), grnxx::Int(0));
+  grnxx::GeoPoint north_pole(grnxx::Float(90.0), grnxx::Float(100.0));
+  grnxx::GeoPoint south_pole(grnxx::Float(-90.0), grnxx::Float(100.0));
+  grnxx::GeoPoint date_line(grnxx::Float(0.0), grnxx::Float(180.0));
+  grnxx::GeoPoint na(grnxx::Int::na(), grnxx::Int::na());
+
+  assert(zero.type() == grnxx::GEO_POINT_DATA);
+  assert(north_pole.type() == grnxx::GEO_POINT_DATA);
+  assert(south_pole.type() == grnxx::GEO_POINT_DATA);
+  assert(date_line.type() == grnxx::GEO_POINT_DATA);
+  assert(na.type() == grnxx::GEO_POINT_DATA);
+
+  assert(zero.latitude() == 0);
+  assert(date_line.latitude() == 0);
+  assert(na.latitude() == grnxx::GeoPoint::na_latitude());
+
+  assert(zero.longitude() == 0);
+  assert(north_pole.longitude() == 0);
+  assert(south_pole.longitude() == 0);
+  assert(na.longitude() == grnxx::GeoPoint::na_longitude());
+
+  assert(zero.latitude_in_milliseconds() == grnxx::Int(0));
+  assert(date_line.latitude_in_milliseconds() == grnxx::Int(0));
+  assert(na.latitude_in_milliseconds().is_na());
+
+  assert(zero.longitude_in_milliseconds() == grnxx::Int(0));
+  assert(north_pole.longitude_in_milliseconds() == grnxx::Int(0));
+  assert(south_pole.longitude_in_milliseconds() == grnxx::Int(0));
+  assert(na.longitude_in_milliseconds().is_na());
+
+  assert(zero.latitude_in_degrees() == grnxx::Float(0.0));
+  assert(north_pole.latitude_in_degrees() == grnxx::Float(90.0));
+  assert(south_pole.latitude_in_degrees() == grnxx::Float(-90.0));
+  assert(date_line.latitude_in_degrees() == grnxx::Float(0.0));
+  assert(na.latitude_in_degrees().is_na());
+
+  assert(zero.longitude_in_degrees() == grnxx::Float(0.0));
+  assert(north_pole.longitude_in_degrees() == grnxx::Float(0.0));
+  assert(south_pole.longitude_in_degrees() == grnxx::Float(0.0));
+  assert(date_line.longitude_in_degrees() == grnxx::Float(-180.0));
+  assert(na.longitude_in_degrees().is_na());
+
+  assert((zero == zero).is_true());
+  assert((zero == north_pole).is_false());
+  assert((zero == south_pole).is_false());
+  assert((zero == date_line).is_false());
+  assert((zero == na).is_na());
+  assert((north_pole == north_pole).is_true());
+  assert((north_pole == south_pole).is_false());
+  assert((north_pole == date_line).is_false());
+  assert((north_pole == na).is_na());
+  assert((south_pole == south_pole).is_true());
+  assert((south_pole == date_line).is_false());
+  assert((south_pole == na).is_na());
+  assert((date_line == date_line).is_true());
+  assert((date_line == na).is_na());
+  assert((na == na).is_na());
+
+  assert((zero != zero).is_false());
+  assert((zero != north_pole).is_true());
+  assert((zero != south_pole).is_true());
+  assert((zero != date_line).is_true());
+  assert((zero != na).is_na());
+  assert((north_pole != north_pole).is_false());
+  assert((north_pole != south_pole).is_true());
+  assert((north_pole != date_line).is_true());
+  assert((north_pole != na).is_na());
+  assert((south_pole != south_pole).is_false());
+  assert((south_pole != date_line).is_true());
+  assert((south_pole != na).is_na());
+  assert((date_line != date_line).is_false());
+  assert((date_line != na).is_na());
+  assert((na != na).is_na());
 }
 
 int main() {
-------------- next part --------------
HTML����������������������������...
Download 



More information about the Groonga-commit mailing list
Back to archive index