[fdo-commits] r688 - trunk/Providers/GenericRdbms/Src/UnitTest/Odbc
svn_fdo at osgeo.org
svn_fdo at osgeo.org
Thu Jan 25 21:51:59 EST 2007
Author: brentrobinson
Date: 2007-01-25 21:51:58 -0500 (Thu, 25 Jan 2007)
New Revision: 688
Modified:
trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcDescribeSchemaTest.cpp
trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcDescribeSchemaTest.h
Log:
Merged from 3.2.x branch
Modified: trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcDescribeSchemaTest.cpp
===================================================================
--- trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcDescribeSchemaTest.cpp 2007-01-26 02:32:59 UTC (rev 687)
+++ trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcDescribeSchemaTest.cpp 2007-01-26 02:51:58 UTC (rev 688)
@@ -39,6 +39,13 @@
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( OdbcTextDescribeSchemaTest, "OdbcTextTests");
#endif
+#ifdef _WIN32
+CPPUNIT_TEST_SUITE_REGISTRATION (OdbcAccessDescribeSchemaTest);
+CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( OdbcAccessDescribeSchemaTest, "DescribeSchemaTest");
+CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( OdbcAccessDescribeSchemaTest, "OdbcAccessDescribeSchemaTest");
+CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( OdbcAccessDescribeSchemaTest, "OdbcAccessTests");
+#endif
+
void OdbcDescribeSchemaTest::LoadTestData(FdoIConnection* connection)
{
UnitTestUtil::Sql2Db( (const wchar_t**) mInputSchema, connection );
@@ -201,4 +208,82 @@
}
}
+void OdbcAccessDescribeSchemaTest::set_provider()
+{
+ UnitTestUtil::SetProvider( "OdbcAccess" );
+}
+
+// The function checks the geometric type property value on a describe schema
+// command execution. It should indicate POINT only.
+// This unit test is for defect 872623
+void OdbcAccessDescribeSchemaTest::describe()
+{
+ try
+ {
+ // call the static method
+ FdoPtr<FdoIConnection> connection = UnitTestUtil::GetProviderConnectionObject();
+ if (connection == NULL)
+ CPPUNIT_FAIL("FAILED - CreateConnection returned NULL\n");
+
+ // Now open the database with the given
+ connection->SetConnectionString(GetConnectString());
+ connection->Open();
+
+ // Now analyse the schema with the mappings in place.
+ // This is a modified version of DescribeSchemaTest::SchemaTest().
+ FdoPtr<FdoIDescribeSchema> describeSchemaCmd =
+ (FdoIDescribeSchema*)connection->CreateCommand(FdoCommandType_DescribeSchema);
+ FdoPtr<FdoFeatureSchemaCollection> schemas = describeSchemaCmd->Execute();
+
+ if (schemas == NULL)
+ CPPUNIT_FAIL("FAILED - DescribeSchema returned NULL collection\n");
+
+ FdoInt32 numSchemas = schemas->GetCount();
+ for (int i=0; i<numSchemas; i++)
+ {
+ FdoPtr<FdoFeatureSchema> schema = schemas->GetItem(i);
+
+ FdoString* schemaName = schema->GetName();
+ wprintf(L"Current schema '%ls'\n", schemaName);
+ FdoPtr<FdoClassCollection> classes = schema->GetClasses();
+
+ FdoInt32 numClasses = classes->GetCount();
+ for (int j=0; j<numClasses; j++)
+ {
+ // Note the assumption here that it is a feature class (it is set up so
+ // in the test data).
+ FdoPtr<FdoClassDefinition> classDef = classes->GetItem(j);
+
+ // analyze the feature class
+ FdoString* className = classDef->GetName();
+ wprintf(L"Current class '%ls'\n", className);
+
+ FdoPropertiesP props = classDef->GetProperties();
+
+ FdoInt32 numProps = props->GetCount();
+ for (int k=0; k<numProps; k++ ) {
+ FdoPropertyP prop = props->GetItem(k);
+
+ if ( prop->GetPropertyType() == FdoPropertyType_GeometricProperty ) {
+ FdoGeometricPropertyDefinition* geomProp = (FdoGeometricPropertyDefinition*)(prop.p);
+
+ wprintf(L"Current geometry property '%ls' '%ls'\n", geomProp->GetName(), geomProp->GetDescription());
+ FdoInt32 geomType = geomProp->GetGeometryTypes();
+ CPPUNIT_ASSERT( geomType == FdoGeometricType_Point );
+ FdoInt32 specGeomCount = 0;
+ FdoGeometryType* specGeomTypes = geomProp->GetSpecificGeometryTypes( specGeomCount );
+ CPPUNIT_ASSERT( specGeomCount == 1 );
+ CPPUNIT_ASSERT( specGeomTypes[0] == FdoGeometryType_Point );
+ }
+ }
+ }
+ }
+ }
+ catch (FdoException *ex)
+ {
+ TestCommonFail (ex);
+ }
+
+}
+
#endif
Modified: trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcDescribeSchemaTest.h
===================================================================
--- trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcDescribeSchemaTest.h 2007-01-26 02:32:59 UTC (rev 687)
+++ trunk/Providers/GenericRdbms/Src/UnitTest/Odbc/OdbcDescribeSchemaTest.h 2007-01-26 02:51:58 UTC (rev 688)
@@ -81,6 +81,18 @@
FdoString * GetPhysicalSchemaName() {return L"";}
};
+class OdbcAccessDescribeSchemaTest : public DescribeSchemaTest
+{
+ CPPUNIT_TEST_SUB_SUITE (OdbcAccessDescribeSchemaTest, DescribeSchemaTest);
+ CPPUNIT_TEST_SUITE_END ();
+
+ void set_provider();
+ virtual void describe ();
+
+ FdoString * GetConfigFile() {return L"MsTestConfig.xml";}
+ FdoString * GetConnectString() {return L"DataSourceName=MsTest;UserId=;Password=;";}
+};
+
#endif
#endif // ODBC_DESCRIBESCHEMA_H
More information about the fdo-commits
mailing list