Fix test sleep on iOS. am: a9f051faac
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/13805070 MUST ONLY BE SUBMITTED BY AUTOMERGER Change-Id: I31ecfb95fb38161e88923743b86a42c609f4b010
This commit is contained in:
@@ -9,6 +9,9 @@
|
||||
#else
|
||||
# include <sys/types.h>
|
||||
#endif
|
||||
#ifdef __APPLE__
|
||||
# include <TargetConditionals.h>
|
||||
#endif
|
||||
|
||||
#include <errno.h>
|
||||
#include <string.h>
|
||||
@@ -73,10 +76,13 @@ bool TestSleep::RollbackSystemTime(int seconds) {
|
||||
file_time.dwHighDateTime = long_time >> 32;
|
||||
if (!FileTimeToSystemTime(&file_time, &time)) return false;
|
||||
if (!SetSystemTime(&time)) return false;
|
||||
#elif TARGET_IPHONE_SIMULATOR || TARGET_OS_IPHONE
|
||||
LOGE("iOS time rollback: cannot set system time.");
|
||||
return false;
|
||||
#else
|
||||
auto time = std::chrono::system_clock::now();
|
||||
auto modified_time = time - std::chrono::seconds(seconds);
|
||||
;
|
||||
|
||||
timespec time_spec;
|
||||
time_spec.tv_sec = std::chrono::duration_cast<std::chrono::seconds>(
|
||||
modified_time.time_since_epoch())
|
||||
@@ -140,6 +146,9 @@ bool TestSleep::CanChangeSystemTime() {
|
||||
}
|
||||
LOGE("Win32 time rollback: cannot set system time.");
|
||||
return false;
|
||||
#elif TARGET_IPHONE_SIMULATOR || TARGET_OS_IPHONE
|
||||
LOGE("iOS time rollback: cannot set system time.");
|
||||
return false;
|
||||
#else
|
||||
// Otherwise, the test needs to be run as root.
|
||||
const uid_t uid = getuid();
|
||||
|
||||
Reference in New Issue
Block a user