X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7c5ac499c84648ef1f58afa1187656f5d72c56d8..a4578b0ceda90e103620894d3aa86284178ab1cd:/tests/strings/crt.cpp diff --git a/tests/strings/crt.cpp b/tests/strings/crt.cpp index 8855068748..e0623f6ac5 100644 --- a/tests/strings/crt.cpp +++ b/tests/strings/crt.cpp @@ -44,6 +44,7 @@ public: private: CPPUNIT_TEST_SUITE( CrtTestCase ); CPPUNIT_TEST( SetGetEnv ); + CPPUNIT_TEST( Strchr ); CPPUNIT_TEST( Strcmp ); CPPUNIT_TEST( Strspn ); CPPUNIT_TEST( Strcspn ); @@ -52,6 +53,7 @@ private: CPPUNIT_TEST_SUITE_END(); void SetGetEnv(); + void Strchr(); void Strcmp(); void Strspn(); void Strcspn(); @@ -69,15 +71,37 @@ CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( CrtTestCase, "CrtTestCase" ); void CrtTestCase::SetGetEnv() { +#define TESTVAR_NAME wxT("WXTESTVAR") + wxString val; - wxSetEnv(_T("TESTVAR"), _T("value")); - CPPUNIT_ASSERT( wxGetEnv(_T("TESTVAR"), &val) == true ); - CPPUNIT_ASSERT( val == _T("value") ); - wxSetEnv(_T("TESTVAR"), _T("something else")); - CPPUNIT_ASSERT( wxGetEnv(_T("TESTVAR"), &val) ); - CPPUNIT_ASSERT( val == _T("something else") ); - CPPUNIT_ASSERT( wxUnsetEnv(_T("TESTVAR")) ); - CPPUNIT_ASSERT( wxGetEnv(_T("TESTVAR"), NULL) == false ); + wxSetEnv(TESTVAR_NAME, wxT("value")); + CPPUNIT_ASSERT( wxGetEnv(TESTVAR_NAME, &val) ); + CPPUNIT_ASSERT_EQUAL( "value", val ); + CPPUNIT_ASSERT_EQUAL( "value", wxString(wxGetenv(TESTVAR_NAME)) ); + + wxSetEnv(TESTVAR_NAME, wxT("something else")); + CPPUNIT_ASSERT( wxGetEnv(TESTVAR_NAME, &val) ); + CPPUNIT_ASSERT_EQUAL( "something else", val ); + CPPUNIT_ASSERT_EQUAL( "something else", wxString(wxGetenv(TESTVAR_NAME)) ); + + CPPUNIT_ASSERT( wxUnsetEnv(TESTVAR_NAME) ); + CPPUNIT_ASSERT( !wxGetEnv(TESTVAR_NAME, NULL) ); + CPPUNIT_ASSERT( !wxGetenv(TESTVAR_NAME) ); + +#undef TESTVAR_NAME +} + +void CrtTestCase::Strchr() +{ + // test that searching for a wide character in a narrow string simply + // doesn't find it but doesn't fail with an assert (#11487) + const wxUniChar smiley = *wxString::FromUTF8("\xe2\x98\xba").begin(); + + CPPUNIT_ASSERT( !wxStrchr("hello", smiley) ); + + // but searching for an explicitly wide character does find it + CPPUNIT_ASSERT( wxStrchr(wxString::FromUTF8(":-) == \xe2\x98\xba"), + static_cast(smiley)) ); } void CrtTestCase::Strcmp() @@ -207,18 +231,12 @@ void CrtTestCase::Strpbrk() CPPUNIT_ASSERT_EQUAL( ',', *wxStrpbrk(strWX.c_str(), s.mb_str()) ); CPPUNIT_ASSERT_EQUAL( L',', *wxStrpbrk(strWX.c_str(), s.wc_str()) ); - CPPUNIT_ASSERT_EQUAL( (char *)NULL, wxStrpbrk(strWX, "xyz") ); - CPPUNIT_ASSERT_EQUAL( (wchar_t *)NULL, wxStrpbrk(strWX.c_str(), L"xyz") ); + CPPUNIT_ASSERT( !wxStrpbrk(strWX, "xyz") ); + CPPUNIT_ASSERT( !wxStrpbrk(strWX.c_str(), L"xyz") ); } void CrtTestCase::Strnlen() { - // the following calls should not segfault/crash because when passing 0 - // as maxlen, no bytes at all should be read from the given buffer - // (which is NULL in this case!) - CPPUNIT_ASSERT_EQUAL( (size_t)0, wxStrnlen((const char*)NULL, 0) ); - CPPUNIT_ASSERT_EQUAL( (size_t)0, wxStrnlen((const wchar_t*)NULL, 0) ); - // other misc tests for wxStrnlen(const char*, size_t) CPPUNIT_ASSERT_EQUAL( (size_t)0, wxStrnlen("", 0) );