Loading...
--- xnu/xnu-12377.121.6/tests/time.c
+++ /dev/null
@@ -1,101 +0,0 @@
-#include <darwintest.h>
-#include <darwintest_utils.h>
-#include <stdlib.h>
-#include <sys/stat.h>
-#include <sys/syslimits.h>
-#include <sys/time.h>
-#include <time.h>
-#include <unistd.h>
-
-T_GLOBAL_META(T_META_CHECK_LEAKS(false));
-
-T_DECL(settimeofday, "check setting and getting time of day",
- T_META_ASROOT(true), T_META_TAG_VM_PREFERRED)
-{
- struct timeval origtime = {};
- struct timezone origtz = {};
- int ret = gettimeofday(&origtime, &origtz);
- T_ASSERT_POSIX_SUCCESS(ret, "get current time with gettimeofday(2)");
-
-#if TARGET_OS_BRIDGE
- /*
- * bridgeOS is not allowed to set the time -- only the macOS side can.
- */
- T_SKIP("bridgeOS is not allowed to call settimeofday(2)");
-#endif /* TARGET_OS_BRIDGE */
-
- struct timeval newtime = {};
- newtime = origtime;
- newtime.tv_sec -= 60;
- ret = settimeofday(&newtime, NULL);
- T_ASSERT_POSIX_SUCCESS(ret,
- "set time back 60 seconds with settimeofday(2)");
-
- ret = gettimeofday(&newtime, NULL);
- T_ASSERT_POSIX_SUCCESS(ret, "get new time with gettimeofday(2)");
-
- T_ASSERT_GT(origtime.tv_sec, newtime.tv_sec,
- "new time should be before original time");
-
- newtime = origtime;
- newtime.tv_sec += 1;
- ret = settimeofday(&newtime, NULL);
- T_ASSERT_POSIX_SUCCESS(ret,
- "set time close to original value with gettimeofday(2)");
-}
-
-static char tmppath[PATH_MAX] = "";
-
-static void
-cleanup_tmpfile(void)
-{
- if (tmppath[0] != '\0') {
- unlink(tmppath);
- }
-}
-
-static int
-create_tmpfile(void)
-{
- const char *tmpdir = dt_tmpdir();
- strlcat(tmppath, tmpdir ? tmpdir : "/tmp", sizeof(tmppath));
- strlcat(tmppath, "/xnu.futimes.XXXXX", sizeof(tmppath));
- T_LOG("creating temporary file at %s", tmppath);
- int fd = mkstemp(tmppath);
- T_ASSERT_POSIX_SUCCESS(fd, "create temporary file");
- T_ATEND(cleanup_tmpfile);
- return fd;
-}
-
-T_DECL(futimes, "check that futimes updates file times",
- T_META_RUN_CONCURRENTLY(true), T_META_TAG_VM_PREFERRED)
-{
- int tmpfd = create_tmpfile();
-
- struct stat stbuf = {};
- int ret = fstat(tmpfd, &stbuf);
- T_ASSERT_POSIX_SUCCESS(ret, "get file metadata with fstat(2)");
- struct timeval amtimes[2] = {};
- TIMESPEC_TO_TIMEVAL(&amtimes[0], &stbuf.st_atimespec);
- TIMESPEC_TO_TIMEVAL(&amtimes[1], &stbuf.st_mtimespec);
-
- amtimes[0].tv_sec -= 120;
- amtimes[1].tv_sec -= 120;
-
- ret = futimes(tmpfd, amtimes);
- T_ASSERT_POSIX_SUCCESS(ret, "update file times with utimes(2)");
-
- ret = fstat(tmpfd, &stbuf);
- T_ASSERT_POSIX_SUCCESS(ret, "get file metadata after update with fstat(2)");
- struct timeval newamtimes[2] = {};
- TIMESPEC_TO_TIMEVAL(&newamtimes[0], &stbuf.st_atimespec);
- TIMESPEC_TO_TIMEVAL(&newamtimes[1], &stbuf.st_mtimespec);
-
- /*
- * Reading the metadata shouldn't count as an access.
- */
- T_ASSERT_EQ(amtimes[0].tv_sec, newamtimes[0].tv_sec,
- "access time matches what was set");
- T_ASSERT_EQ(amtimes[1].tv_sec, newamtimes[1].tv_sec,
- "modification time matches what was set");
-}