Index: util/test/scoped_temp_dir_test_posix.cc |
diff --git a/util/test/scoped_temp_dir_test_posix.cc b/util/test/scoped_temp_dir_test_posix.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..10fe79f4664d35a7b8bd559132b5409d9473f1ce |
--- /dev/null |
+++ b/util/test/scoped_temp_dir_test_posix.cc |
@@ -0,0 +1,107 @@ |
+// Copyright 2014 The Crashpad Authors. All rights reserved. |
Mark Mentovai
2014/12/31 05:51:10
I see why you named it this way, but I think that
Robert Sesek
2015/01/02 17:34:09
Done.
|
+// |
+// Licensed under the Apache License, Version 2.0 (the "License"); |
+// you may not use this file except in compliance with the License. |
+// You may obtain a copy of the License at |
+// |
+// http://www.apache.org/licenses/LICENSE-2.0 |
+// |
+// Unless required by applicable law or agreed to in writing, software |
+// distributed under the License is distributed on an "AS IS" BASIS, |
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
+// See the License for the specific language governing permissions and |
+// limitations under the License. |
+ |
+#include "util/test/scoped_temp_dir.h" |
+ |
+#include <errno.h> |
+#include <fcntl.h> |
+#include <string.h> |
+#include <sys/stat.h> |
+#include <unistd.h> |
+ |
+#include "base/posix/eintr_wrapper.h" |
+#include "gtest/gtest.h" |
+#include "util/test/errors.h" |
+ |
+namespace crashpad { |
+namespace test { |
+namespace { |
+ |
+bool FileExists(const base::FilePath& path) { |
+ struct stat st; |
+ int rv = stat(path.value().c_str(), &st); |
Mark Mentovai
2014/12/31 05:51:10
I think it’s good to be in the habit of calling ls
Robert Sesek
2015/01/02 17:34:09
Done.
|
+ if (rv < 0) { |
+ EXPECT_EQ(ENOENT, errno) << "stat expected ENOENT, got " << strerror(errno); |
Mark Mentovai
2014/12/31 05:51:10
The message kinda repeats what the code says, exce
Robert Sesek
2015/01/02 17:34:09
Done.
|
+ return false; |
+ } |
+ return true; |
+} |
+ |
+TEST(ScopedTempDir, Empty) { |
+ base::FilePath path; |
+ { |
+ ScopedTempDir dir; |
+ path = dir.path(); |
+ EXPECT_TRUE(FileExists(path)); |
+ } |
+ EXPECT_FALSE(FileExists(path)); |
+} |
+ |
+TEST(ScopedTempDir, WithTwoFiles) { |
+ base::FilePath parent, file1, file2; |
+ |
+ { |
+ ScopedTempDir dir; |
+ parent = dir.path(); |
+ ASSERT_TRUE(FileExists(parent)); |
+ |
+ file1 = parent.Append("test1"); |
+ int fd = HANDLE_EINTR(creat(file1.value().c_str(), 0644)); |
Mark Mentovai
2014/12/31 05:51:10
The ASSERT_GE(fd, 0) << ErrnoMessage("creat") is m
Robert Sesek
2015/01/02 17:34:09
Done.
|
+ IGNORE_EINTR(close(fd)); |
+ ASSERT_TRUE(FileExists(file1)); |
Mark Mentovai
2014/12/31 05:51:10
This can be EXPECT_TRUE() since it isn’t a precond
Robert Sesek
2015/01/02 17:34:09
Done.
|
+ |
+ file2 = parent.Append("test 2"); |
Mark Mentovai
2014/12/31 05:51:10
Spaces! Happy to see that.
You should also test w
Robert Sesek
2015/01/02 17:34:09
Done.
|
+ fd = HANDLE_EINTR(creat(file2.value().c_str(), 0644)); |
+ IGNORE_EINTR(close(fd)); |
+ ASSERT_TRUE(FileExists(file2)); |
+ } |
+ |
+ EXPECT_FALSE(FileExists(file1)); |
+ EXPECT_FALSE(FileExists(file2)); |
+ EXPECT_FALSE(FileExists(parent)); |
+} |
+ |
+TEST(ScopedTempDir, WithRecursiveDirectory) { |
+ base::FilePath parent, file1, child_dir, file2; |
+ |
+ { |
+ ScopedTempDir dir; |
+ parent = dir.path(); |
+ ASSERT_TRUE(FileExists(parent)); |
+ |
+ file1 = parent.Append("first-level file"); |
+ int fd = HANDLE_EINTR(creat(file1.value().c_str(), 0644)); |
+ IGNORE_EINTR(close(fd)); |
+ ASSERT_TRUE(FileExists(file1)); |
Mark Mentovai
2014/12/31 05:51:10
Same here and on line 96. Line 91 needs to stay an
Robert Sesek
2015/01/02 17:34:09
Done.
|
+ |
+ child_dir = parent.Append("subdir"); |
+ ASSERT_EQ(0, mkdir(child_dir.value().c_str(), 0755)) |
+ << ErrnoMessage("mkdir"); |
+ ASSERT_TRUE(FileExists(child_dir)); |
+ |
+ file2 = child_dir.Append("second level file"); |
+ fd = HANDLE_EINTR(creat(file2.value().c_str(), 0644)); |
+ IGNORE_EINTR(close(fd)); |
+ ASSERT_TRUE(FileExists(file2)); |
+ } |
+ |
+ EXPECT_FALSE(FileExists(file1)); |
+ EXPECT_FALSE(FileExists(file2)); |
+ EXPECT_FALSE(FileExists(child_dir)); |
+ EXPECT_FALSE(FileExists(parent)); |
+} |
+ |
+} // namespace |
+} // namespace test |
+} // namespace crashpad |