Index: native_client_sdk/src/tests/nacl_io_test/syscalls_test.cc |
diff --git a/native_client_sdk/src/tests/nacl_io_test/syscalls_test.cc b/native_client_sdk/src/tests/nacl_io_test/syscalls_test.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..c8d790ffe7b9bbfd4eb039be59592c683a197520 |
--- /dev/null |
+++ b/native_client_sdk/src/tests/nacl_io_test/syscalls_test.cc |
@@ -0,0 +1,94 @@ |
+// Copyright (c) 2014 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 <errno.h> |
+#include <limits.h> |
+#include <stdio.h> |
+#include <stdlib.h> |
+#include <sys/stat.h> |
+ |
+#include "gtest/gtest.h" |
+ |
+#include "nacl_io/kernel_intercept.h" |
+#include "nacl_io/kernel_proxy.h" |
+ |
+using namespace nacl_io; |
+ |
+namespace { |
+ |
+class SyscallsTest : public ::testing::Test { |
+ public: |
+ SyscallsTest() {} |
+ |
+ void SetUp() { |
+ ASSERT_EQ(0, ki_push_state_for_testing()); |
+ ASSERT_EQ(0, ki_init(&kp_)); |
+ // Unmount the passthrough FS and mount a memfs. |
+ EXPECT_EQ(0, kp_.umount("/")); |
+ EXPECT_EQ(0, kp_.mount("", "/", "memfs", 0, NULL)); |
+ } |
+ |
+ void TearDown() { ki_uninit(); } |
+ |
+ protected: |
+ KernelProxy kp_; |
+}; |
+ |
+} // namespace |
+ |
+#if defined(__native_client__) |
+ |
+TEST_F(SyscallsTest, Realpath) { |
+ char buffer[PATH_MAX]; |
+ |
+ ASSERT_EQ(0, ki_mkdir("/foo", S_IREAD | S_IWRITE)); |
Sam Clegg
2014/05/21 23:39:21
If you wrote these tests with everything happening
binji
2014/05/21 23:56:01
Hm, good idea. I thought I needed write access to
|
+ ASSERT_EQ(0, ki_mkdir("/foo/bar", S_IREAD | S_IWRITE)); |
+ int fd = ki_open("/foo/file", O_CREAT | O_RDWR); |
+ ASSERT_GT(fd, -1); |
+ ASSERT_EQ(0, ki_close(fd)); |
+ |
+ // Test absolute paths. |
+ EXPECT_STREQ("/", realpath("/", buffer)); |
+ EXPECT_STREQ("/", realpath("/foo/..", buffer)); |
+ EXPECT_STREQ("/foo", realpath("/foo", buffer)); |
+ EXPECT_STREQ("/foo", realpath("/foo/", buffer)); |
+ EXPECT_STREQ("/foo", realpath("/foo/bar/..", buffer)); |
+ EXPECT_STREQ("/foo", realpath("/foo/bar/../bar/../../foo", buffer)); |
+ EXPECT_STREQ("/foo", realpath("/foo/././", buffer)); |
+ EXPECT_STREQ("/foo", realpath("///foo", buffer)); |
+ EXPECT_STREQ("/foo/bar", realpath("/foo/bar", buffer)); |
+ |
+ EXPECT_EQ(NULL, realpath("/blah", buffer)); |
+ EXPECT_EQ(ENOENT, errno); |
+ |
+ EXPECT_EQ(NULL, realpath("/blah/blah", buffer)); |
+ EXPECT_EQ(ENOENT, errno); |
+ |
+ EXPECT_EQ(NULL, realpath("/foo/baz/..", buffer)); |
+ EXPECT_EQ(ENOENT, errno); |
+ |
+ EXPECT_EQ(NULL, realpath("/foo/file/", buffer)); |
+ EXPECT_EQ(ENOTDIR, errno); |
+ |
+ EXPECT_EQ(NULL, realpath(NULL, buffer)); |
+ EXPECT_EQ(EINVAL, errno); |
+ |
+ // Test relative paths. |
+ EXPECT_EQ(0, ki_chdir("/foo")); |
+ |
+ EXPECT_STREQ("/", realpath("..", buffer)); |
+ EXPECT_STREQ("/foo", realpath(".", buffer)); |
+ EXPECT_STREQ("/foo", realpath("./", buffer)); |
+ EXPECT_STREQ("/foo", realpath("bar/..", buffer)); |
+ EXPECT_STREQ("/foo", realpath("bar/../../foo", buffer)); |
+ EXPECT_STREQ("/foo", realpath(".///", buffer)); |
+ EXPECT_STREQ("/foo/bar", realpath("bar", buffer)); |
+ |
+ // Test when resolved_path is allocated. |
+ char* allocated = realpath("/foo", NULL); |
+ EXPECT_STREQ("/foo", allocated); |
+ free(allocated); |
+} |
+ |
+#endif // defined(__native_client__) |