#include <gtest/gtest.h> #include "base/files/file_watcher.h" #include "base/logging.h" namespace { class FileWatcherTest : public ::testing::Test{ protected: FileWatcherTest(){}; virtual ~FileWatcherTest(){}; virtual void SetUp() { }; virtual void TearDown() { }; }; //! gejun: check basic functions of base::FileWatcher TEST_F(FileWatcherTest, random_op) { srand (time(0)); base::FileWatcher fw; EXPECT_EQ (0, fw.init("dummy_file")); for (int i=0; i<30; ++i) { if (rand() % 2) { LOG(INFO) << "watch: " << noflush; const base::FileWatcher::Change ret = fw.check_and_consume(); switch (ret) { case base::FileWatcher::UPDATED: LOG(INFO) << fw.filepath() << " is updated"; break; case base::FileWatcher::CREATED: LOG(INFO) << fw.filepath() << " is created"; break; case base::FileWatcher::DELETED: LOG(INFO) << fw.filepath() << " is deleted"; break; case base::FileWatcher::UNCHANGED: LOG(INFO) << fw.filepath() << " does not change or still not exist"; break; } LOG(INFO); } switch (rand() % 2) { case 0: system ("touch dummy_file"); LOG(INFO) << "action: touch dummy_file"; break; case 1: system ("rm -f dummy_file"); LOG(INFO) << "action: rm -f dummy_file"; break; case 2: LOG(INFO) << "action: (nothing)"; break; } usleep (10000); } system ("rm -f dummy_file"); } }