diff options
author | Elliott Hughes <enh@google.com> | 2014-01-17 18:42:49 -0800 |
---|---|---|
committer | Elliott Hughes <enh@google.com> | 2014-02-18 15:39:24 -0800 |
commit | db1ea3474899ebbd783aba872d3005f95a816d0f (patch) | |
tree | b70fedd7d69098f5141dbbb09ef41851a61eec8d /tests/fcntl_test.cpp | |
parent | 3623d80675e5321b92c2d88a7b7ec6bd998d81d5 (diff) | |
download | android_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.cpp | 33 |
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) { |