aboutsummaryrefslogtreecommitdiffstats
path: root/tests/fcntl_test.cpp
diff options
context:
space:
mode:
authorElliott Hughes <enh@google.com>2014-01-17 18:42:49 -0800
committerElliott Hughes <enh@google.com>2014-02-18 15:39:24 -0800
commitdb1ea3474899ebbd783aba872d3005f95a816d0f (patch)
treeb70fedd7d69098f5141dbbb09ef41851a61eec8d /tests/fcntl_test.cpp
parent3623d80675e5321b92c2d88a7b7ec6bd998d81d5 (diff)
downloadandroid_bionic-db1ea3474899ebbd783aba872d3005f95a816d0f.tar.gz
android_bionic-db1ea3474899ebbd783aba872d3005f95a816d0f.tar.bz2
android_bionic-db1ea3474899ebbd783aba872d3005f95a816d0f.zip
Implement some of the missing LFS64 support.
This gives us: * <dirent.h> struct dirent64 readdir64, readdir64_r, alphasort64, scandir64 * <fcntl.h> creat64, openat64, open64. * <sys/stat.h> struct stat64 fstat64, fstatat64, lstat64, stat64. * <sys/statvfs.h> struct statvfs64 statvfs64, fstatvfs64. * <sys/vfs.h> struct statfs64 statfs64, fstatfs64. This also removes some of the incorrect #define hacks we've had in the past (for stat64, for example, which we promised to clean up way back in bug 8472078). Bug: 11865851 Bug: 8472078 Change-Id: Ia46443521918519f2dfa64d4621027dfd13ac566
Diffstat (limited to 'tests/fcntl_test.cpp')
-rw-r--r--tests/fcntl_test.cpp33
1 files changed, 33 insertions, 0 deletions
diff --git a/tests/fcntl_test.cpp b/tests/fcntl_test.cpp
index d14243e72..4aac46823 100644
--- a/tests/fcntl_test.cpp
+++ b/tests/fcntl_test.cpp
@@ -35,6 +35,39 @@ TEST(fcntl, fcntl_smoke) {
flags = fcntl(fd, F_GETFD);
ASSERT_TRUE(flags != -1);
ASSERT_EQ(FD_CLOEXEC, flags & FD_CLOEXEC);
+
+ close(fd);
+}
+
+TEST(fcntl, open_open64) {
+ int fd;
+
+ fd = open("/proc/version", O_RDONLY);
+ ASSERT_TRUE(fd != -1);
+ close(fd);
+
+ fd = open64("/proc/version", O_RDONLY);
+ ASSERT_TRUE(fd != -1);
+ close(fd);
+}
+
+TEST(fcntl, openat_openat64) {
+ int fd;
+
+ fd = openat(AT_FDCWD, "/proc/version", O_RDONLY);
+ ASSERT_TRUE(fd != -1);
+ close(fd);
+
+ fd = openat64(AT_FDCWD, "/proc/version", O_RDONLY);
+ ASSERT_TRUE(fd != -1);
+ close(fd);
+}
+
+TEST(fcntl, creat_creat64) {
+ ASSERT_EQ(-1, creat("", 0666));
+ ASSERT_EQ(ENOENT, errno);
+ ASSERT_EQ(-1, creat64("", 0666));
+ ASSERT_EQ(ENOENT, errno);
}
TEST(fcntl, fallocate_EINVAL) {