]> git.saurik.com Git - wxWidgets.git/blobdiff - tests/config/config.cpp
Fixed wxAtomicInc/Dec() to not use asm/atomic.h header on Linux - it's kernel interna...
[wxWidgets.git] / tests / config / config.cpp
index 1fc9a47dc5f7159ebd932bb0cc953b0846acb6d0..408d4d7b1159946d7fd81b506f9a003d3dade97d 100644 (file)
@@ -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;
 }