Index: base/dir_reader_posix_unittest.cc |
diff --git a/base/dir_reader_posix_unittest.cc b/base/dir_reader_posix_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..04f7243fc274b1b37b9cc8387b34005a7e94fbaa |
--- /dev/null |
+++ b/base/dir_reader_posix_unittest.cc |
@@ -0,0 +1,91 @@ |
+// Copyright (c) 2010 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "base/dir_reader_posix.h" |
+ |
+#include <fcntl.h> |
+#include <stdio.h> |
+#include <stdlib.h> |
+#include <string.h> |
+#include <unistd.h> |
+ |
+#include "base/logging.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+using base::DirReaderPosix; |
+ |
+namespace { |
+typedef testing::Test DirReaderPosixUnittest; |
+ |
+TEST(DirReaderPosixUnittest, Read) { |
+ static const unsigned kNumFiles = 100; |
+ |
+ if (DirReaderPosix::IsFallback()) |
+ return; |
+ |
+ char kDirTemplate[] = "/tmp/org.chromium.dir-reader-posix-XXXXXX"; |
+ const char* dir = mkdtemp(kDirTemplate); |
+ CHECK(dir); |
+ |
+ const int prev_wd = open(".", O_RDONLY | O_DIRECTORY); |
+ CHECK_GE(prev_wd, 0); |
+ |
+ PCHECK(chdir(dir) == 0); |
+ |
+ for (unsigned i = 0; i < kNumFiles; i++) { |
+ char buf[16]; |
+ snprintf(buf, sizeof(buf), "%d", i); |
+ const int fd = open(buf, O_CREAT | O_RDONLY | O_EXCL, 0600); |
+ PCHECK(fd >= 0); |
+ PCHECK(close(fd) == 0); |
+ } |
+ |
+ std::set<unsigned> seen; |
+ |
+ DirReaderPosix reader(dir); |
+ EXPECT_TRUE(reader.IsValid()); |
+ |
+ if (!reader.IsValid()) |
+ return; |
+ |
+ bool seen_dot = false, seen_dotdot = false; |
+ |
+ for (; reader.Next(); ) { |
+ if (strcmp(reader.name(), ".") == 0) { |
+ seen_dot = true; |
+ continue; |
+ } |
+ if (strcmp(reader.name(), "..") == 0) { |
+ seen_dotdot = true; |
+ continue; |
+ } |
+ |
+ SCOPED_TRACE(testing::Message() << "reader.name(): " << reader.name()); |
+ |
+ char *endptr; |
+ const unsigned long value = strtoul(reader.name(), &endptr, 10); |
+ |
+ EXPECT_FALSE(*endptr); |
+ EXPECT_LT(value, kNumFiles); |
+ EXPECT_EQ(0u, seen.count(value)); |
+ seen.insert(value); |
+ } |
+ |
+ for (unsigned i = 0; i < kNumFiles; i++) { |
+ char buf[16]; |
+ snprintf(buf, sizeof(buf), "%d", i); |
+ PCHECK(unlink(buf) == 0); |
+ } |
+ |
+ PCHECK(rmdir(dir) == 0); |
+ |
+ PCHECK(fchdir(prev_wd) == 0); |
+ PCHECK(close(prev_wd) == 0); |
+ |
+ EXPECT_TRUE(seen_dot); |
+ EXPECT_TRUE(seen_dotdot); |
+ EXPECT_EQ(kNumFiles, seen.size()); |
+} |
+ |
+} // anonymous namespace |