[fdo-commits] r680 - in trunk/Utilities/TestCommon: Inc Src

svn_fdo at osgeo.org svn_fdo at osgeo.org
Fri Jan 26 14:25:27 EST 2007


Author: brentrobinson
Date: 2007-01-26 14:25:27 -0500 (Fri, 26 Jan 2007)
New Revision: 680

Modified:
   trunk/Utilities/TestCommon/Inc/TestCommonConstraints.h
   trunk/Utilities/TestCommon/Src/TestCommonConstraints.cpp
   trunk/Utilities/TestCommon/Src/TestCommonMiscUtil.cpp
Log:
Merged from 3.2.x branch

Modified: trunk/Utilities/TestCommon/Inc/TestCommonConstraints.h
===================================================================
--- trunk/Utilities/TestCommon/Inc/TestCommonConstraints.h	2007-01-26 17:49:11 UTC (rev 679)
+++ trunk/Utilities/TestCommon/Inc/TestCommonConstraints.h	2007-01-26 19:25:27 UTC (rev 680)
@@ -62,7 +62,8 @@
 
     virtual FdoIConnection* CreateConnection( FdoBoolean recreateDb = false );
     virtual FdoBoolean CanRestrictCheckConstraint();
-    virtual FdoBoolean CanHandleExactFloatValue();
+    virtual FdoDouble GetDoubleRounding(FdoDataType dataType);
+    virtual FdoFloat GetSecondsIncrement();
 
     virtual FdoInt32 GetExpectedCheckConstraintCount( FdoIConnection* connection );
 

Modified: trunk/Utilities/TestCommon/Src/TestCommonConstraints.cpp
===================================================================
--- trunk/Utilities/TestCommon/Src/TestCommonConstraints.cpp	2007-01-26 17:49:11 UTC (rev 679)
+++ trunk/Utilities/TestCommon/Src/TestCommonConstraints.cpp	2007-01-26 19:25:27 UTC (rev 680)
@@ -1296,34 +1296,31 @@
         CPPUNIT_ASSERT_MESSAGE("Should get check constraint violation prop #3", checkSuccess == false );
 
 
-        if ( CanHandleExactFloatValue() ) {
+        TestCommonMiscUtil::InsertObject(
+            connection,
+            insertCmd,
+            SCHEMA_NAME,
+            CLASS_NAME,
+            PROP_FEATID, FdoDataType_Int32, 99999999,
+            PROP_INT32_R , FdoDataType_Int32,  (FdoInt32) 10,
+            PROP_INT32_L,  FdoDataType_Int32,  (FdoInt32) 20,
+            PROP_STRING_L,  FdoDataType_String, L"open",
+            PROP_UNIQUE1,  FdoDataType_Int32,  (FdoInt32) 8000,
+            PROP_UNIQUE2_1,  FdoDataType_Int32,  (FdoInt32) 8000,
+            (FdoString*) NULL
+        );
 
-            TestCommonMiscUtil::InsertObject(
-                connection,
-                insertCmd,
-                SCHEMA_NAME,
-                CLASS_NAME,
-                PROP_FEATID, FdoDataType_Int32, 99999999,
-                PROP_INT32_R , FdoDataType_Int32,  (FdoInt32) 10,
-                PROP_INT32_L,  FdoDataType_Int32,  (FdoInt32) 20,
-                PROP_STRING_L,  FdoDataType_String, L"open",
-                PROP_UNIQUE1,  FdoDataType_Int32,  (FdoInt32) 8000,
-                PROP_UNIQUE2_1,  FdoDataType_Int32,  (FdoInt32) 8000,
-                (FdoString*) NULL
-            );
+        UpdateAllValues( connection, CLASS_NAME, 99999999);
 
-            UpdateAllValues( connection, CLASS_NAME, 99999999);
-
-            TestCommonMiscUtil::DeleteObjects( 
-                connection,
-                SCHEMA_NAME,
-                CLASS_NAME,
-                PROP_FEATID,
-                FdoDataType_Int32,
-                (FdoInt32) 99999999,
-                NULL
-            );
-        }
+        TestCommonMiscUtil::DeleteObjects( 
+            connection,
+            SCHEMA_NAME,
+            CLASS_NAME,
+            PROP_FEATID,
+            FdoDataType_Int32,
+            (FdoInt32) 99999999,
+            NULL
+        );
     }
 }
 
@@ -1338,7 +1335,7 @@
     UpdateRangeIntegralValues( connection, pClassName, PROP_FEATID, featId, PROP_INT32_R, INT32_RANGE );
     UpdateRangeIntegralValues( connection, pClassName, PROP_FEATID, featId, PROP_INT64_R, INT64_RANGE );
     UpdateRangeDoubleValues( connection, pClassName, PROP_FEATID, featId, PROP_DOUBLE_R, FdoDataType_Double, DOUBLE_RANGE );
-    if ( CanHandleExactFloatValue() )
+    if ( GetDoubleRounding(FdoDataType_Decimal) == 0 )
         UpdateRangeDoubleValues( connection, pClassName, PROP_FEATID, featId, PROP_DECIMAL_R, FdoDataType_Decimal, DOUBLE_RANGE );
     UpdateRangeSingleValues( connection, pClassName, PROP_FEATID, featId);
     UpdateRangeStringValues( connection, pClassName, PROP_FEATID, featId);
@@ -1348,7 +1345,7 @@
     UpdateListValues( connection, pClassName, PROP_FEATID, featId, PROP_INT32_L, INT32_LIST[1], (FdoInt32) 500 );
     UpdateListValues( connection, pClassName, PROP_FEATID, featId, PROP_INT64_L, INT64_LIST[1], (FdoInt64) 800 );
     
-    if ( this->CanHandleExactFloatValue() ) {
+    if ( GetDoubleRounding(FdoDataType_Decimal) == 0 ) {
         UpdateListDoubleValues( connection, pClassName, PROP_FEATID, featId, PROP_DOUBLE_L, FdoDataType_Double);
         UpdateListValues( connection, pClassName, PROP_FEATID, featId, PROP_SINGLE_L, SINGLE_LIST[1], (FdoFloat) 200.43 );
     }
@@ -1371,24 +1368,10 @@
     FdoPtr<FdoDataValueCollection> badValues = FdoDataValueCollection::Create();
     FdoPtr<FdoDataValueCollection> goodValues = FdoDataValueCollection::Create();
 
-    badValues->Add( 
-        FdoPtr<FdoDataValue>(
-            FdoDataValue::Create(
-               this->CanHandleExactFloatValue() ? (FdoDouble) pRange[0] : (FdoDouble)(pRange[0] - 0.01), 
-                dataType
-            )
-        ) 
-    );
-    badValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create((FdoDouble)(pRange[1] + 0.01), dataType)) );
-    goodValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create((FdoDouble) (pRange[0] + 0.01), dataType)) );
-    goodValues->Add( 
-        FdoPtr<FdoDataValue>(
-            FdoDataValue::Create(
-                this->CanHandleExactFloatValue() ? (FdoDouble)pRange[1] : (FdoDouble)(pRange[1] - 0.01), 
-                dataType
-            )
-        ) 
-    );
+    badValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create((FdoDouble)(pRange[0] - GetDoubleRounding(dataType)), dataType)) );
+    badValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create((FdoDouble)(pRange[1] + 0.05), dataType)) );
+    goodValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create((FdoDouble) (pRange[0] + 0.05), dataType)) );
+    goodValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create((FdoDouble)(pRange[1] - GetDoubleRounding(dataType)), dataType)) );
 
     UpdateRangeValues( connection, pClassName, pIdName, idValue, pPropName, goodValues, badValues );
 }
@@ -1442,10 +1425,10 @@
     badValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create(dateTime)) );
     dateTime = minDateTime;
     dateTime.minute = dateTime.minute - 1;
-    dateTime.seconds = (FdoFloat)(dateTime.seconds + 0.001);
+    dateTime.seconds = (FdoFloat)(dateTime.seconds + GetSecondsIncrement());
     badValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create(dateTime)) );
     dateTime = minDateTime;
-    dateTime.seconds = (FdoFloat)(dateTime.seconds - 0.001);
+    dateTime.seconds = (FdoFloat)(dateTime.seconds - GetSecondsIncrement());
     badValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create(dateTime)) );
 
     dateTime = maxDateTime;
@@ -1467,9 +1450,9 @@
     dateTime = maxDateTime;
     dateTime.minute = dateTime.minute + 1;
     badValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create(dateTime)) );
-    dateTime.seconds = (FdoFloat)(dateTime.seconds - 0.001);
+    dateTime.seconds = (FdoFloat)(dateTime.seconds - GetSecondsIncrement());
     dateTime = maxDateTime;
-    dateTime.seconds = (FdoFloat)(dateTime.seconds + 0.001);
+    dateTime.seconds = (FdoFloat)(dateTime.seconds + GetSecondsIncrement());
     badValues->Add( FdoPtr<FdoDataValue>(FdoDataValue::Create(dateTime)) );
 
     UpdateRangeValues( connection, pClassName, pIdName, idValue, PROP_DATE_R, goodValues, badValues );
@@ -3424,11 +3407,16 @@
     return true;
 }
 
-FdoBoolean TestCommonConstraints::CanHandleExactFloatValue()
+FdoDouble TestCommonConstraints::GetDoubleRounding(FdoDataType dataType)
 {
-    return true;
+    return (FdoDouble) 0.0;
 }
 
+FdoFloat TestCommonConstraints::GetSecondsIncrement()
+{
+    return (FdoFloat) 0.001;
+}
+
 FdoInt32 TestCommonConstraints::GetExpectedCheckConstraintCount( FdoIConnection* connection )
 {
     FdoPtr<FdoISchemaCapabilities>    schemaCap = connection->GetSchemaCapabilities();

Modified: trunk/Utilities/TestCommon/Src/TestCommonMiscUtil.cpp
===================================================================
--- trunk/Utilities/TestCommon/Src/TestCommonMiscUtil.cpp	2007-01-26 17:49:11 UTC (rev 679)
+++ trunk/Utilities/TestCommon/Src/TestCommonMiscUtil.cpp	2007-01-26 19:25:27 UTC (rev 680)
@@ -133,6 +133,7 @@
     FdoByte byteArg;
     FdoInt32 int32Arg;
     FdoFloat floatArg;
+    FdoDouble doubleArg;
     FdoString* strArg;
 
     FdoDataType dataType = (FdoDataType) va_arg(arguments,int);
@@ -154,6 +155,11 @@
         floatArg = (FdoFloat) va_arg(arguments,double);
         dataValue = FdoDataValue::Create(floatArg);
         break;
+    case FdoDataType_Double:
+    case FdoDataType_Decimal:
+        doubleArg = (FdoDouble) va_arg(arguments,double);
+        dataValue = FdoDataValue::Create(doubleArg, dataType);
+        break;
     case FdoDataType_String:
         strArg = va_arg(arguments,FdoString*);
         dataValue = FdoDataValue::Create(strArg);



More information about the fdo-commits mailing list