X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/3e1512cdfecd2c531567e6603083d9c3968216c7..b150bffc9e137b1fbcb29592512642f65ed331f2:/tests/config/config.cpp diff --git a/tests/config/config.cpp b/tests/config/config.cpp index 1fc9a47dc5..408d4d7b11 100644 --- a/tests/config/config.cpp +++ b/tests/config/config.cpp @@ -43,6 +43,7 @@ private: void ReadWriteLocalTest(); void RecordingDefaultsTest(); + void ReadValues(wxConfig *config, bool has_values); DECLARE_NO_COPY_CLASS(ConfigTestCase) }; @@ -73,101 +74,101 @@ void ConfigTestCase::ReadWriteLocalTest() config = new wxConfig(app, vendor, wxT(""), wxT(""), wxCONFIG_USE_LOCAL_FILE); wxString string1 = config->Read(wxT("string1")); - CPPUNIT_ASSERT( string1 == wxT("abc") ); + CPPUNIT_ASSERT_EQUAL( string1, wxString(wxT("abc")) ); string1 = config->Read(wxT("string1"), wxT("defaultvalue")); - CPPUNIT_ASSERT( string1 == wxT("abc") ); + CPPUNIT_ASSERT_EQUAL( string1, wxString(wxT("abc")) ); + wxString string2; bool r = config->Read(wxT("string2"), &string2); - CPPUNIT_ASSERT( r == true ); - CPPUNIT_ASSERT( string2 == wxT("def") ); + CPPUNIT_ASSERT( r ); + CPPUNIT_ASSERT_EQUAL( string2, wxString(wxT("def")) ); + r = config->Read(wxT("string2"), &string2, wxT("defaultvalue")); - CPPUNIT_ASSERT( r == true ); - CPPUNIT_ASSERT( string2 == wxT("def") ); + CPPUNIT_ASSERT( r ); + CPPUNIT_ASSERT_EQUAL( string2, wxString(wxT("def")) ); + int int1 = config->Read(wxT("int1"), 5); - CPPUNIT_ASSERT( int1 == 123 ); + CPPUNIT_ASSERT_EQUAL( int1, 123 ); + long long1; r = config->Read(wxT("long1"), &long1); - CPPUNIT_ASSERT( r == true ); - CPPUNIT_ASSERT( long1 == 234 ); + CPPUNIT_ASSERT( r ); + CPPUNIT_ASSERT_EQUAL( long1, 234L ); + + CPPUNIT_ASSERT( config->ReadLong(wxT("long1"), 0) == 234 ); + + double double1; + r = config->Read(wxT("double1"), &double1); + CPPUNIT_ASSERT( r ); + CPPUNIT_ASSERT_EQUAL( double1, 345.67 ); + + CPPUNIT_ASSERT( config->ReadDouble(wxT("double1"), 0) == double1 ); + bool bool1; - r = config->Read(wxT("foo"), &bool1); - CPPUNIT_ASSERT( r == false ); + r = config->Read(wxT("foo"), &bool1); // there is no "foo" key + CPPUNIT_ASSERT( !r ); + r = config->Read(wxT("bool1"), &bool1); - CPPUNIT_ASSERT( r == true ); - CPPUNIT_ASSERT( bool1 == true ); + CPPUNIT_ASSERT( r ); + CPPUNIT_ASSERT_EQUAL( bool1, true ); + + CPPUNIT_ASSERT( config->ReadBool(wxT("bool1"), false) == bool1 ); + wxColour color1; r = config->Read(wxT("color1"), &color1); - CPPUNIT_ASSERT( r == true ); + CPPUNIT_ASSERT( r ); CPPUNIT_ASSERT( color1 == wxColour(11,22,33,44) ); + + CPPUNIT_ASSERT( config->ReadObject(wxT("color1"), wxNullColour) == color1 ); + config->DeleteAll(); delete config; } -void ConfigTestCase::RecordingDefaultsTest() +void ConfigTestCase::ReadValues(wxConfig *config, bool has_values) { - wxString app = wxT("wxConfigTestCaseRD"); - wxString vendor = wxT("wxWidgets"); - wxConfig *config = new wxConfig(app, vendor, wxT(""), wxT(""), - wxCONFIG_USE_LOCAL_FILE); - config->DeleteAll(); - config->SetRecordDefaults(false); // by default it is false - wxString string1, string2, string3, string4; - string1 = config->Read(wxT("string1"), wxT("abc")); - string2 = config->Read(wxT("string2"), wxString(wxT("def"))); - config->Read(wxT("string3"), &string3, wxT("abc")); - config->Read(wxT("string4"), &string4, wxString(wxT("def"))); - int int1, int2; - config->Read(wxT("int1"), &int1, 123); - int2 = config->Read(wxT("int2"), 1234); - long long1; - config->Read(wxString(wxT("long1")), &long1, 234L); - double double1; - config->Read(wxT("double1"), &double1, 345.67); - bool bool1; - config->Read(wxT("bool1"), &bool1, true); - wxColour color1; - config->Read(wxT("color1"), &color1, wxColour(11,22,33,44)); - - CPPUNIT_ASSERT ( config->GetNumberOfEntries() == 0 ); - - config->SetRecordDefaults(true); - bool r; - string1 = config->Read(wxT("string1"), wxT("abc")); - string2 = config->Read(wxT("string2"), wxString(wxT("def"))); + wxString string1 = config->Read(wxT("string1"), wxT("abc")); + wxString string2 = config->Read(wxT("string2"), wxString(wxT("def"))); + wxString string3, string4; r = config->Read(wxT("string3"), &string3, wxT("abc")); - CPPUNIT_ASSERT( r == false ); + CPPUNIT_ASSERT_EQUAL( r, has_values ); r = config->Read(wxT("string4"), &string4, wxString(wxT("def"))); - CPPUNIT_ASSERT( r == false ); + CPPUNIT_ASSERT_EQUAL( r, has_values ); + int int1; r = config->Read(wxT("int1"), &int1, 123); - CPPUNIT_ASSERT( r == false ); - int2 = config->Read(wxT("int2"), 1234); + CPPUNIT_ASSERT_EQUAL( r, has_values ); + int int2 = config->Read(wxT("int2"), 1234); + CPPUNIT_ASSERT_EQUAL( int2, 1234 ); + long long1; r = config->Read(wxString(wxT("long1")), &long1, 234L); - CPPUNIT_ASSERT( r == false ); + CPPUNIT_ASSERT_EQUAL( r, has_values ); + double double1; r = config->Read(wxT("double1"), &double1, 345.67); - CPPUNIT_ASSERT( r == false ); + CPPUNIT_ASSERT_EQUAL( r, has_values ); + bool bool1; r = config->Read(wxT("bool1"), &bool1, true); - CPPUNIT_ASSERT( r == false ); + CPPUNIT_ASSERT_EQUAL( r, has_values ); + wxColour color1; r = config->Read(wxT("color1"), &color1, wxColour(11,22,33,44)); - CPPUNIT_ASSERT( r == false ); + CPPUNIT_ASSERT_EQUAL( r, has_values ); +} - CPPUNIT_ASSERT ( config->GetNumberOfEntries() == 10 ); - - r = config->Read(wxT("string3"), &string3, wxT("abc")); - CPPUNIT_ASSERT( r == true ); - r = config->Read(wxT("string4"), &string4, wxString(wxT("def"))); - CPPUNIT_ASSERT( r == true ); - r = config->Read(wxT("int1"), &int1, 123); - CPPUNIT_ASSERT( r == true ); - r = config->Read(wxString(wxT("long1")), &long1, 234L); - CPPUNIT_ASSERT( r == true ); - r = config->Read(wxT("double1"), &double1, 345.67); - CPPUNIT_ASSERT( r == true ); - r = config->Read(wxT("bool1"), &bool1, true); - CPPUNIT_ASSERT( r == true ); - r = config->Read(wxT("color1"), &color1, wxColour(11,22,33,44)); - CPPUNIT_ASSERT( r == true ); +void ConfigTestCase::RecordingDefaultsTest() +{ + wxString app = wxT("wxConfigTestCaseRD"); + wxString vendor = wxT("wxWidgets"); + wxConfig *config = new wxConfig(app, vendor, wxT(""), wxT(""), + wxCONFIG_USE_LOCAL_FILE); + config->DeleteAll(); + config->SetRecordDefaults(false); // by default it is false + ReadValues(config, false); + CPPUNIT_ASSERT_EQUAL( (int) config->GetNumberOfEntries(), 0 ); + config->SetRecordDefaults(true); + ReadValues(config, false); + CPPUNIT_ASSERT_EQUAL( (int) config->GetNumberOfEntries(), 10 ); + ReadValues(config, true); config->DeleteAll(); delete config; }