]> git.saurik.com Git - wxWidgets.git/blobdiff - tests/intl/intltest.cpp
Applied patch #15540: wxRichTextTable: crashes due to an invalid focus object (dghart)
[wxWidgets.git] / tests / intl / intltest.cpp
index 2b2c4b83e05e797578acdbeedf2c56b564d51dff..11f6451afeeb48e946e23c326f1f4f7bdcc1af7c 100644 (file)
@@ -3,7 +3,6 @@
 // Purpose:     wxLocale unit test
 // Author:      Vaclav Slavik
 // Created:     2007-03-26
 // Purpose:     wxLocale unit test
 // Author:      Vaclav Slavik
 // Created:     2007-03-26
-// RCS-ID:      $Id$
 // Copyright:   (c) 2007 Vaclav Slavik
 ///////////////////////////////////////////////////////////////////////////////
 
 // Copyright:   (c) 2007 Vaclav Slavik
 ///////////////////////////////////////////////////////////////////////////////
 
 class IntlTestCase : public CppUnit::TestCase
 {
 public:
 class IntlTestCase : public CppUnit::TestCase
 {
 public:
-    IntlTestCase() {}
+    IntlTestCase() { m_locale=NULL; }
 
     virtual void setUp();
     virtual void tearDown();
 
 private:
     CPPUNIT_TEST_SUITE( IntlTestCase );
 
     virtual void setUp();
     virtual void tearDown();
 
 private:
     CPPUNIT_TEST_SUITE( IntlTestCase );
+        CPPUNIT_TEST( RestoreLocale );
         CPPUNIT_TEST( Domain );
         CPPUNIT_TEST( Headers );
         CPPUNIT_TEST( Domain );
         CPPUNIT_TEST( Headers );
+        CPPUNIT_TEST( DateTimeFmtFrench );
+        CPPUNIT_TEST( DateTimeFmtC );
+        CPPUNIT_TEST( IsAvailable );
     CPPUNIT_TEST_SUITE_END();
 
     CPPUNIT_TEST_SUITE_END();
 
+    void RestoreLocale();
     void Domain();
     void Headers();
     void Domain();
     void Headers();
+    void DateTimeFmtFrench();
+    void DateTimeFmtC();
+    void IsAvailable();
+
+    static wxString GetDecimalPoint()
+    {
+        return wxLocale::GetInfo(wxLOCALE_DECIMAL_POINT, wxLOCALE_CAT_NUMBER);
+    }
 
     wxLocale *m_locale;
 
 
     wxLocale *m_locale;
 
@@ -54,16 +66,24 @@ private:
 // register in the unnamed registry so that these tests are run by default
 CPPUNIT_TEST_SUITE_REGISTRATION( IntlTestCase );
 
 // register in the unnamed registry so that these tests are run by default
 CPPUNIT_TEST_SUITE_REGISTRATION( IntlTestCase );
 
-// also include in it's own registry so that these tests can be run alone
+// also include in its own registry so that these tests can be run alone
 CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( IntlTestCase, "IntlTestCase" );
 
 void IntlTestCase::setUp()
 {
 CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( IntlTestCase, "IntlTestCase" );
 
 void IntlTestCase::setUp()
 {
+    // Check that French locale is supported, this test doesn't work without it
+    // and all the other function need to check whether m_locale is non-NULL
+    // before continuing
+    if ( !wxLocale::IsAvailable(wxLANGUAGE_FRENCH) )
+        return;
+
     wxLocale::AddCatalogLookupPathPrefix("./intl");
 
     m_locale = new wxLocale;
     wxLocale::AddCatalogLookupPathPrefix("./intl");
 
     m_locale = new wxLocale;
+    CPPUNIT_ASSERT( m_locale );
+
     // don't load default catalog, it may be unavailable:
     // don't load default catalog, it may be unavailable:
-    bool loaded = m_locale->Init(wxLANGUAGE_FRENCH, wxLOCALE_CONV_ENCODING);
+    bool loaded = m_locale->Init(wxLANGUAGE_FRENCH, wxLOCALE_DONT_LOAD_DEFAULT);
     CPPUNIT_ASSERT( loaded );
 
     m_locale->AddCatalog("internat");
     CPPUNIT_ASSERT( loaded );
 
     m_locale->AddCatalog("internat");
@@ -71,47 +91,158 @@ void IntlTestCase::setUp()
 
 void IntlTestCase::tearDown()
 {
 
 void IntlTestCase::tearDown()
 {
-    delete m_locale;
-    m_locale = NULL;
+    if (m_locale)
+    {
+        delete m_locale;
+        m_locale = NULL;
+    }
+}
+
+void IntlTestCase::RestoreLocale()
+{
+    if ( !m_locale )
+        return;
+
+    // We must be using the French locale now, it was changed in setUp().
+    CPPUNIT_ASSERT_EQUAL( ",", GetDecimalPoint() );
+
+    // Switch to the English locale.
+    {
+        wxLocale locEn(wxLANGUAGE_ENGLISH);
+        CPPUNIT_ASSERT_EQUAL( ".", GetDecimalPoint() );
+    }
+
+    // Verify that after destroying the English locale object, French locale is
+    // restored.
+    CPPUNIT_ASSERT_EQUAL( ",", GetDecimalPoint() );
 }
 
 void IntlTestCase::Domain()
 {
 }
 
 void IntlTestCase::Domain()
 {
+    if (!m_locale)
+        return;
+
     // _() searches all domains by default:
     // _() searches all domains by default:
-    CPPUNIT_ASSERT( _("&Open bogus file") == "&Ouvrir un fichier" );
+    CPPUNIT_ASSERT_EQUAL( "&Ouvrir un fichier", _("&Open bogus file") );
 
     // search in our domain only:
 
     // search in our domain only:
-    CPPUNIT_ASSERT( wxGetTranslation("&Open bogus file", "internat") ==
-                    "&Ouvrir un fichier" );
+    CPPUNIT_ASSERT_EQUAL( "&Ouvrir un fichier", wxGetTranslation("&Open bogus file", "internat") );
 
     // search in a domain that doesn't have this string:
 
     // search in a domain that doesn't have this string:
-    CPPUNIT_ASSERT( wxGetTranslation("&Open bogus file", "BogusDomain") ==
-                    "&Open bogus file" );
+    CPPUNIT_ASSERT_EQUAL( "&Open bogus file", wxGetTranslation("&Open bogus file", "BogusDomain") );
 }
 
 void IntlTestCase::Headers()
 {
 }
 
 void IntlTestCase::Headers()
 {
-    CPPUNIT_ASSERT( m_locale->GetHeaderValue("Project-Id-Version") ==
-                    "wxWindows 2.0 i18n sample" );
-    CPPUNIT_ASSERT( m_locale->GetHeaderValue("POT-Creation-Date") ==
-                    "1999-01-13 18:19+0100" );
-    CPPUNIT_ASSERT( m_locale->GetHeaderValue("PO-Revision-Date") ==
-                    "YEAR-MO-DA HO:MI+ZONE" );
-    CPPUNIT_ASSERT( m_locale->GetHeaderValue("Last-Translator") ==
-                    "Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>" );
-    CPPUNIT_ASSERT( m_locale->GetHeaderValue("MIME-Version") ==
-                    "1.0" );
-    CPPUNIT_ASSERT( m_locale->GetHeaderValue("Content-Type") ==
-                    "text/plain; charset=iso-8859-1" );
-    CPPUNIT_ASSERT( m_locale->GetHeaderValue("Content-Transfer-Encoding") ==
-                    "8bit" );
+    if ( !m_locale )
+        return;
+
+    CPPUNIT_ASSERT_EQUAL( "wxWindows 2.0 i18n sample", m_locale->GetHeaderValue("Project-Id-Version") );
+    CPPUNIT_ASSERT_EQUAL( "1999-01-13 18:19+0100", m_locale->GetHeaderValue("POT-Creation-Date") );
+    CPPUNIT_ASSERT_EQUAL( "YEAR-MO-DA HO:MI+ZONE", m_locale->GetHeaderValue("PO-Revision-Date") );
+    CPPUNIT_ASSERT_EQUAL( "Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>", m_locale->GetHeaderValue("Last-Translator") );
+    CPPUNIT_ASSERT_EQUAL( "1.0", m_locale->GetHeaderValue("MIME-Version") );
+    CPPUNIT_ASSERT_EQUAL( "text/plain; charset=utf-8", m_locale->GetHeaderValue("Content-Type") );
+    CPPUNIT_ASSERT_EQUAL( "8bit", m_locale->GetHeaderValue("Content-Transfer-Encoding") );
 
     // check that it fails with a bogus domain:
 
     // check that it fails with a bogus domain:
-    CPPUNIT_ASSERT( m_locale->GetHeaderValue("POT-Creation-Date", "Bogus") ==
-                    "" );
+    CPPUNIT_ASSERT_EQUAL( "", m_locale->GetHeaderValue("POT-Creation-Date", "Bogus") );
 
     // and that it fails for nonexisting header:
 
     // and that it fails for nonexisting header:
-    CPPUNIT_ASSERT( m_locale->GetHeaderValue("X-Not-Here") == "" );
+    CPPUNIT_ASSERT_EQUAL( "", m_locale->GetHeaderValue("X-Not-Here") );
+}
+
+static wxString
+NormalizeFormat(const wxString& fmtOrig)
+{
+    wxString fmt(fmtOrig);
+
+#ifdef __GLIBC__
+    // glibc uses some extensions in its formats which we need to convert to
+    // standard form
+    fmt.Replace("%T", "%H:%M:%S");
+    fmt.Replace("%e", "%d");
+#endif // __GLIBC__
+
+    return fmt;
+}
+
+#define WX_ASSERT_EQUAL_FORMAT(msg, expected, actual) \
+    if ( !actual.empty() ) \
+        CPPUNIT_ASSERT_EQUAL_MESSAGE(msg, expected, NormalizeFormat(actual))
+
+void IntlTestCase::DateTimeFmtFrench()
+{
+    if ( !m_locale )
+        return;
+
+#ifdef __GLIBC__
+    // Versions of glibc up to 2.7 wrongly used periods for French locale
+    // separator.
+#if __GLIBC__ > 2 || __GLIBC_MINOR__ >= 8
+    static const char *FRENCH_DATE_FMT = "%d/%m/%Y";
+#else
+    static const char *FRENCH_DATE_FMT = "%d.%m.%Y";
+#endif
+    static const char *FRENCH_LONG_DATE_FMT = "%a %d %b %Y";
+    static const char *FRENCH_DATE_TIME_FMT = "%a %d %b %Y %H:%M:%S %Z";
+#else
+    static const char *FRENCH_DATE_FMT = "%d/%m/%Y";
+    static const char *FRENCH_LONG_DATE_FMT = "%A %d %B %Y";
+#ifdef __WXOSX__
+    static const char *FRENCH_DATE_TIME_FMT = "%A %d %B %Y %H:%M:%S";
+#else
+    static const char *FRENCH_DATE_TIME_FMT = "%d/%m/%Y %H:%M:%S";
+#endif
+#endif
+
+    WX_ASSERT_EQUAL_FORMAT( "French short date", FRENCH_DATE_FMT,
+                   m_locale->GetInfo(wxLOCALE_SHORT_DATE_FMT) );
+    WX_ASSERT_EQUAL_FORMAT( "French long date", FRENCH_LONG_DATE_FMT,
+                    m_locale->GetInfo(wxLOCALE_LONG_DATE_FMT) );
+    WX_ASSERT_EQUAL_FORMAT( "French date and time", FRENCH_DATE_TIME_FMT,
+                    m_locale->GetInfo(wxLOCALE_DATE_TIME_FMT) );
+    WX_ASSERT_EQUAL_FORMAT( "French time", "%H:%M:%S",
+                    m_locale->GetInfo(wxLOCALE_TIME_FMT) );
+}
+
+void IntlTestCase::DateTimeFmtC()
+{
+    // again, glibc uses different defaults
+#ifdef __GLIBC__
+    static const char *C_DATE_FMT = "%m/%d/%y";
+    static const char *C_LONG_DATE_FMT = "%a %b %d %Y";
+    static const char *C_DATE_TIME_FMT = "%a %b %d %H:%M:%S %Y";
+#else
+    static const char *C_DATE_FMT = "%d/%m/%Y";
+    static const char *C_LONG_DATE_FMT = "%A %d %B %Y";
+#ifdef __WXOSX__
+    static const char *C_DATE_TIME_FMT = "%A %d %B %Y %H:%M:%S";
+#else
+    static const char *C_DATE_TIME_FMT = "%d/%m/%Y %H:%M:%S";
+#endif
+#endif
+
+    setlocale(LC_ALL, "C");
+
+    WX_ASSERT_EQUAL_FORMAT( "C short date", C_DATE_FMT,
+                    m_locale->GetInfo(wxLOCALE_SHORT_DATE_FMT) );
+    WX_ASSERT_EQUAL_FORMAT( "C long date", C_LONG_DATE_FMT,
+                    m_locale->GetInfo(wxLOCALE_LONG_DATE_FMT) );
+    WX_ASSERT_EQUAL_FORMAT( "C date and time", C_DATE_TIME_FMT,
+                    m_locale->GetInfo(wxLOCALE_DATE_TIME_FMT) );
+    WX_ASSERT_EQUAL_FORMAT( "C time", "%H:%M:%S",
+                    m_locale->GetInfo(wxLOCALE_TIME_FMT) );
+}
+
+void IntlTestCase::IsAvailable()
+{
+    const wxString origLocale(setlocale(LC_ALL, NULL));
+
+    // Calling IsAvailable() shouldn't change the locale.
+    wxLocale::IsAvailable(wxLANGUAGE_ENGLISH);
+
+    CPPUNIT_ASSERT_EQUAL( origLocale, setlocale(LC_ALL, NULL) );
 }
 
 #endif // wxUSE_INTL
 }
 
 #endif // wxUSE_INTL