]> git.saurik.com Git - wxWidgets.git/commitdiff
Add wxImplicitConversionType tests.
authorVáclav Slavík <vslavik@fastmail.fm>
Mon, 25 Oct 2010 09:43:04 +0000 (09:43 +0000)
committerVáclav Slavík <vslavik@fastmail.fm>
Mon, 25 Oct 2010 09:43:04 +0000 (09:43 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@65921 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

tests/misc/metatest.cpp

index 1fcefd245cd0f9c8d3a376a75a4e67ca737cf8dd..ed1d4c388e927c84649aae44f95093282f9e0ebe 100644 (file)
 #endif
 
 #include "wx/object.h"
+#include "wx/utils.h"
 #include "wx/meta/pod.h"
 #include "wx/meta/movable.h"
 
+#ifndef wxNO_RTTI
+#include <typeinfo>
+#endif
+
 // ----------------------------------------------------------------------------
 // test class
 // ----------------------------------------------------------------------------
@@ -30,10 +35,12 @@ private:
     CPPUNIT_TEST_SUITE( MetaProgrammingTestCase );
         CPPUNIT_TEST( IsPod );
         CPPUNIT_TEST( IsMovable );
+        CPPUNIT_TEST( ImplicitConversion );
     CPPUNIT_TEST_SUITE_END();
 
     void IsPod();
     void IsMovable();
+    void ImplicitConversion();
 
     DECLARE_NO_COPY_CLASS(MetaProgrammingTestCase)
 };
@@ -67,3 +74,21 @@ void MetaProgrammingTestCase::IsMovable()
 #endif
     CPPUNIT_ASSERT(!wxIsMovable<wxObject>::value);
 }
+
+void MetaProgrammingTestCase::ImplicitConversion()
+{
+    // wxImplicitConversionType<> is used to implement wxMax(). We test it
+    // indirectly through that here.
+
+    // test that wxMax(1.1,1) returns float, not long int
+    float f = wxMax(1.1f, 1l);
+    CPPUNIT_ASSERT_EQUAL( 1.1f, f);
+
+#ifndef wxNO_RTTI
+    CPPUNIT_ASSERT(typeid(wxImplicitConversionType<char,int>::value) == typeid(int));
+    CPPUNIT_ASSERT(typeid(wxImplicitConversionType<int,unsigned>::value) == typeid(unsigned));
+#ifdef wxLongLong_t
+    CPPUNIT_ASSERT(typeid(wxImplicitConversionType<wxLongLong_t,float>::value) == typeid(float));
+#endif
+#endif // !wxNO_RTTI
+}