X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/25db2c25bc488fcdd10cc5d2fd4938fd78b1cf0e..661698e54f2bc599dc1a961ffbae08ccdd6b9b97:/tests/filename/filenametest.cpp diff --git a/tests/filename/filenametest.cpp b/tests/filename/filenametest.cpp index c975cfc363..64100e85a6 100644 --- a/tests/filename/filenametest.cpp +++ b/tests/filename/filenametest.cpp @@ -35,6 +35,7 @@ #endif // __UNIX__ #include "testfile.h" +#include "testdate.h" // ---------------------------------------------------------------------------- // test data @@ -139,6 +140,7 @@ private: CPPUNIT_TEST( TestVolumeUniqueName ); CPPUNIT_TEST( TestCreateTempFileName ); CPPUNIT_TEST( TestGetTimes ); + CPPUNIT_TEST( TestSetTimes ); CPPUNIT_TEST( TestExists ); CPPUNIT_TEST( TestIsSame ); #if defined(__UNIX__) @@ -161,6 +163,7 @@ private: void TestVolumeUniqueName(); void TestCreateTempFileName(); void TestGetTimes(); + void TestSetTimes(); void TestExists(); void TestIsSame(); #if defined(__UNIX__) @@ -664,6 +667,31 @@ void FileNameTestCase::TestGetTimes() CPPUNIT_ASSERT(dtAccess.IsEqualUpTo(wxDateTime::Now(), wxTimeSpan(0,1))); } +void FileNameTestCase::TestSetTimes() +{ + wxFileName fn(wxFileName::CreateTempFileName("filenametest")); + CPPUNIT_ASSERT( fn.IsOk() ); + wxON_BLOCK_EXIT1( wxRemoveFile, fn.GetFullPath() ); + + const wxDateTime dtAccess(1, wxDateTime::Jan, 2013); + const wxDateTime dtModify(1, wxDateTime::Feb, 2013); + const wxDateTime dtCreate(1, wxDateTime::Mar, 2013); + + CPPUNIT_ASSERT( fn.SetTimes(&dtAccess, &dtModify, &dtCreate) ); + + wxDateTime dtAccess2, + dtModify2, + dtCreate2; + CPPUNIT_ASSERT( fn.GetTimes(&dtAccess2, &dtModify2, &dtCreate2) ); + CPPUNIT_ASSERT_EQUAL( dtAccess, dtAccess2 ); + CPPUNIT_ASSERT_EQUAL( dtModify, dtModify2 ); + + // Under Unix the creation time can't be set. +#ifdef __WINDOWS__ + CPPUNIT_ASSERT_EQUAL( dtCreate, dtCreate2 ); +#endif // __WINDOWS__ +} + void FileNameTestCase::TestExists() { wxFileName fn(wxFileName::CreateTempFileName("filenametest")); @@ -673,8 +701,17 @@ void FileNameTestCase::TestExists() CPPUNIT_ASSERT( fn.FileExists() ); CPPUNIT_ASSERT( !wxFileName::DirExists(fn.GetFullPath()) ); + // FIXME-VC6: This compiler crashes with + // + // fatal error C1001: INTERNAL COMPILER ERROR + // (compiler file 'msc1.cpp', line 1794) + // + // when compiling calls to Exists() with parameter for some reason, just + // disable these tests there. +#ifndef __VISUALC6__ CPPUNIT_ASSERT( fn.Exists(wxFILE_EXISTS_REGULAR) ); CPPUNIT_ASSERT( !fn.Exists(wxFILE_EXISTS_DIR) ); +#endif CPPUNIT_ASSERT( fn.Exists() ); const wxString& tempdir = wxFileName::GetTempDir(); @@ -687,8 +724,10 @@ void FileNameTestCase::TestExists() CPPUNIT_ASSERT( !dirTemp.FileExists() ); CPPUNIT_ASSERT( dirTemp.DirExists() ); +#ifndef __VISUALC6__ CPPUNIT_ASSERT( dirTemp.Exists(wxFILE_EXISTS_DIR) ); CPPUNIT_ASSERT( !dirTemp.Exists(wxFILE_EXISTS_REGULAR) ); +#endif CPPUNIT_ASSERT( dirTemp.Exists() ); #ifdef __UNIX__ @@ -698,18 +737,19 @@ void FileNameTestCase::TestExists() CPPUNIT_ASSERT( wxFileName::Exists("/dev/null", wxFILE_EXISTS_DEVICE) ); #ifdef __LINUX__ // These files are only guaranteed to exist under Linux. - CPPUNIT_ASSERT( !wxFileName::Exists("/dev/core", wxFILE_EXISTS_SYMLINK) ); - CPPUNIT_ASSERT( wxFileName::Exists("/dev/core", - wxFILE_EXISTS_SYMLINK | wxFILE_EXISTS_NO_FOLLOW) ); + // No need for wxFILE_EXISTS_NO_FOLLOW here; wxFILE_EXISTS_SYMLINK implies it + CPPUNIT_ASSERT( wxFileName::Exists("/dev/core", wxFILE_EXISTS_SYMLINK) ); CPPUNIT_ASSERT( wxFileName::Exists("/dev/log", wxFILE_EXISTS_SOCKET) ); #endif // __LINUX__ +#ifndef __VMS wxString fifo = dirTemp.GetPath() + "/fifo"; - if (mkfifo(fifo.c_str(), 0600) == 0) + if (mkfifo(fifo.c_str(), 0600) == 0) { wxON_BLOCK_EXIT1(wxRemoveFile, fifo); CPPUNIT_ASSERT( wxFileName::Exists(fifo, wxFILE_EXISTS_FIFO) ); } +#endif #endif // __UNIX__ } @@ -774,9 +814,15 @@ void FileNameTestCase::TestSymlinks() CPPUNIT_ASSERT(tmpfn.GetTimes(&dtAccessTmp, &dtModTmp, &dtCreateTmp)); // Create a temporary directory +#ifdef __VMS + wxString name = tmpdir + ".filenametestXXXXXX]"; + mkdir( name.char_str() , 0222 ); + wxString tempdir = name; +#else wxString name = tmpdir + "/filenametestXXXXXX"; wxString tempdir = wxString::From8BitData(mkdtemp(name.char_str())); tempdir << wxFileName::GetPathSeparator(); +#endif wxFileName tempdirfn(wxFileName::DirName(tempdir)); CPPUNIT_ASSERT(tempdirfn.DirExists()); @@ -923,7 +969,15 @@ void FileNameTestCase::TestSymlinks() // Finally test Exists() after removing the file. CPPUNIT_ASSERT(wxRemoveFile(targetfn.GetFullPath())); - CPPUNIT_ASSERT(!wxFileName(tempdir, "linktofile").Exists()); + // This should succeed, as the symlink still exists and + // the default wxFILE_EXISTS_ANY implies wxFILE_EXISTS_NO_FOLLOW + CPPUNIT_ASSERT(wxFileName(tempdir, "linktofile").Exists()); + // So should this one, as wxFILE_EXISTS_SYMLINK does too + CPPUNIT_ASSERT(wxFileName(tempdir, "linktofile"). + Exists(wxFILE_EXISTS_SYMLINK)); + // but not this one, as the now broken symlink is followed + CPPUNIT_ASSERT(!wxFileName(tempdir, "linktofile"). + Exists(wxFILE_EXISTS_REGULAR)); CPPUNIT_ASSERT(linktofile.Exists()); // This is also a convenient place to test Rmdir() as we have things to