| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204 | 
							- ///////////////////////////////////////////////////////////////////////////////
 
- // Name:        tests/misc/safearrayconverttest.cpp
 
- // Purpose:     Test conversions between wxVariant and OLE VARIANT using SAFEARRAYs
 
- // Author:      PB
 
- // RCS-ID:      $Id: typeinfotest.cpp 67656 2011-04-30 10:57:04Z DS $
 
- // Copyright:   (c) the wxWidgets team
 
- // Licence:     wxWindows licence
 
- ///////////////////////////////////////////////////////////////////////////////
 
- #include "testprec.h"
 
- #ifdef __BORLANDC__
 
-     #pragma hdrstop
 
- #endif
 
- #ifdef __WINDOWS__
 
- #if wxUSE_OLE && wxUSE_VARIANT
 
- #include "wx/msw/ole/oleutils.h"
 
- #include "wx/msw/ole/safearray.h"
 
- // need this to be able to use CPPUNIT_ASSERT_EQUAL with wxVariant objects
 
- inline std::ostream& operator<<(std::ostream& ostr, const wxVariant& v)
 
- {
 
-     ostr << v.GetString();
 
-     return ostr;
 
- }
 
- // ----------------------------------------------------------------------------
 
- // test class
 
- // ----------------------------------------------------------------------------
 
- class SafeArrayConvertTestCase  : public CppUnit::TestCase
 
- {
 
- public:
 
-     SafeArrayConvertTestCase () { }
 
- private:
 
-      CPPUNIT_TEST_SUITE( SafeArrayConvertTestCase  );
 
-         CPPUNIT_TEST( VariantListDefault );
 
-         CPPUNIT_TEST( VariantStringsDefault );
 
-         CPPUNIT_TEST( VariantListReturnSafeArray );
 
-         CPPUNIT_TEST( StringsReturnSafeArray );
 
-      CPPUNIT_TEST_SUITE_END();
 
-     void VariantListDefault();
 
-     void VariantStringsDefault();
 
-     void VariantListReturnSafeArray();
 
-     void StringsReturnSafeArray();
 
-     DECLARE_NO_COPY_CLASS(SafeArrayConvertTestCase )
 
- };
 
- // register in the unnamed registry so that these tests are run by default
 
- CPPUNIT_TEST_SUITE_REGISTRATION( SafeArrayConvertTestCase  );
 
- // also include in its own registry so that these tests can be run alone
 
- CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( SafeArrayConvertTestCase, "SafeArrayConvertTestCase" );
 
- // test converting a wxVariant with the list type to an OLE VARIANT
 
- // and back to wxVariant the list type
 
- void SafeArrayConvertTestCase::VariantListDefault()
 
- {
 
-     wxVariant variant;
 
-     VARIANT oleVariant;
 
-     variant.NullList();
 
-     variant.Append(true);
 
-     variant.Append(12.34);
 
-     variant.Append(42L);
 
-     variant.Append("ABC");
 
-     CPPUNIT_ASSERT( wxConvertVariantToOle(variant, oleVariant) );
 
-     wxVariant variantCopy;
 
-     CPPUNIT_ASSERT( wxConvertOleToVariant(oleVariant, variantCopy) );
 
-     CPPUNIT_ASSERT( variant == variantCopy );
 
- }
 
- // test converting a wxVariant with the arrstring type to an OLE VARIANT
 
- // and back to a wxVariant with the arrstring type
 
- void SafeArrayConvertTestCase::VariantStringsDefault()
 
- {
 
-     wxVariant variant;
 
-     wxArrayString as;
 
-     VARIANT oleVariant;
 
-     as.push_back("abc");
 
-     as.push_back("def");
 
-     as.push_back("ghi");
 
-     variant = as;
 
-     CPPUNIT_ASSERT( wxConvertVariantToOle(variant, oleVariant) );
 
-     wxVariant variantCopy;
 
-     CPPUNIT_ASSERT( wxConvertOleToVariant(oleVariant, variantCopy) );
 
-     CPPUNIT_ASSERT( variant == variantCopy );
 
- }
 
- // test converting a wxVariant with the list type to an OLE VARIANT
 
- // and then to a wxVariant with the safearray type
 
- void SafeArrayConvertTestCase::VariantListReturnSafeArray()
 
- {
 
-     wxVariant variant;
 
-     VARIANT oleVariant;
 
-     variant.NullList();
 
-     variant.Append(true);
 
-     variant.Append(12.34);
 
-     variant.Append(42L);
 
-     variant.Append("test");
 
-     CPPUNIT_ASSERT( wxConvertVariantToOle(variant, oleVariant) );
 
-     wxVariant variantCopy;
 
-     CPPUNIT_ASSERT(
 
-         wxConvertOleToVariant(oleVariant, variantCopy,
 
-                               wxOleConvertVariant_ReturnSafeArrays)
 
-     );
 
-     CPPUNIT_ASSERT( variantCopy.GetType() == wxT("safearray") );
 
-     wxSafeArray<VT_VARIANT> safeArray;
 
-     wxVariantDataSafeArray*
 
-         vsa = wxStaticCastVariantData(variantCopy.GetData(),
 
-                                       wxVariantDataSafeArray);
 
-     long bound;
 
-     CPPUNIT_ASSERT( vsa );
 
-     CPPUNIT_ASSERT( safeArray.Attach(vsa->GetValue()) );
 
-     CPPUNIT_ASSERT_EQUAL( 1, safeArray.GetDim() );
 
-     CPPUNIT_ASSERT( safeArray.GetLBound(1, bound) );
 
-     CPPUNIT_ASSERT_EQUAL( 0, bound );
 
-     CPPUNIT_ASSERT( safeArray.GetUBound(1, bound) );
 
-     const long count = variant.GetCount();
 
-     // bound + 1 because safearray elements are accessed by index ranging from
 
-     // LBound to UBound inclusive
 
-     CPPUNIT_ASSERT_EQUAL( bound + 1, count );
 
-     wxVariant variantItem;
 
-     for ( long i = 0; i < count; i++ )
 
-     {
 
-         CPPUNIT_ASSERT( safeArray.GetElement(&i, variantItem) );
 
-         CPPUNIT_ASSERT_EQUAL( variantItem, variant[i] );
 
-     }
 
- }
 
- // test converting a wxArrayString to an OLE VARIANT
 
- // and then to a wxVariant with the safearray type
 
- void SafeArrayConvertTestCase::StringsReturnSafeArray()
 
- {
 
-     wxArrayString as;
 
-     wxSafeArray<VT_BSTR> safeArray;
 
-     as.push_back("abc");
 
-     as.push_back("def");
 
-     as.push_back("ghi");
 
-     CPPUNIT_ASSERT( safeArray.CreateFromArrayString(as) );
 
-     VARIANT oleVariant;
 
-     wxVariant variant;
 
-     oleVariant.vt = VT_BSTR | VT_ARRAY;
 
-     oleVariant.parray = safeArray.Detach();
 
-     CPPUNIT_ASSERT( oleVariant.parray );
 
-     CPPUNIT_ASSERT(
 
-         wxConvertOleToVariant(oleVariant, variant,
 
-                               wxOleConvertVariant_ReturnSafeArrays)
 
-     );
 
-     CPPUNIT_ASSERT( variant.GetType() == wxT("safearray") );
 
-     wxVariantDataSafeArray*
 
-         vsa = wxStaticCastVariantData(variant.GetData(),
 
-                                       wxVariantDataSafeArray);
 
-     long bound;
 
-     CPPUNIT_ASSERT( vsa );
 
-     CPPUNIT_ASSERT( safeArray.Attach(vsa->GetValue()) );
 
-     CPPUNIT_ASSERT_EQUAL( 1, safeArray.GetDim() );
 
-     CPPUNIT_ASSERT( safeArray.GetLBound(1, bound) );
 
-     CPPUNIT_ASSERT_EQUAL( 0, bound );
 
-     CPPUNIT_ASSERT( safeArray.GetUBound(1, bound) );
 
-     const long count = as.size();
 
-     CPPUNIT_ASSERT_EQUAL( bound + 1, count );
 
-     wxString str;
 
-     for ( long i = 0; i < count; i++ )
 
-     {
 
-         CPPUNIT_ASSERT( safeArray.GetElement(&i, str) );
 
-         CPPUNIT_ASSERT( str == as[i] );
 
-     }
 
- }
 
- #endif // __WINDOWS__
 
- #endif // wxUSE_OLE && wxUSE_VARIANT
 
 
  |