Removed the Requirement to Install Python and NodeJS (Now Bundled with Borealis)
This commit is contained in:
78
Dependencies/Python/Lib/test/test_capi/test_time.py
vendored
Normal file
78
Dependencies/Python/Lib/test/test_capi/test_time.py
vendored
Normal file
@ -0,0 +1,78 @@
|
||||
import time
|
||||
import unittest
|
||||
from test.support import import_helper
|
||||
_testcapi = import_helper.import_module('_testcapi')
|
||||
|
||||
|
||||
PyTime_MIN = _testcapi.PyTime_MIN
|
||||
PyTime_MAX = _testcapi.PyTime_MAX
|
||||
SEC_TO_NS = 10 ** 9
|
||||
DAY_TO_SEC = (24 * 60 * 60)
|
||||
# Worst clock resolution: maximum delta between two clock reads.
|
||||
CLOCK_RES = 0.050
|
||||
|
||||
|
||||
class CAPITest(unittest.TestCase):
|
||||
def test_min_max(self):
|
||||
# PyTime_t is just int64_t
|
||||
self.assertEqual(PyTime_MIN, -2**63)
|
||||
self.assertEqual(PyTime_MAX, 2**63 - 1)
|
||||
|
||||
def test_assecondsdouble(self):
|
||||
# Test PyTime_AsSecondsDouble()
|
||||
def ns_to_sec(ns):
|
||||
if abs(ns) % SEC_TO_NS == 0:
|
||||
return float(ns // SEC_TO_NS)
|
||||
else:
|
||||
return float(ns) / SEC_TO_NS
|
||||
|
||||
seconds = (
|
||||
0,
|
||||
1,
|
||||
DAY_TO_SEC,
|
||||
365 * DAY_TO_SEC,
|
||||
)
|
||||
values = {
|
||||
PyTime_MIN,
|
||||
PyTime_MIN + 1,
|
||||
PyTime_MAX - 1,
|
||||
PyTime_MAX,
|
||||
}
|
||||
for second in seconds:
|
||||
ns = second * SEC_TO_NS
|
||||
values.add(ns)
|
||||
# test nanosecond before/after to test rounding
|
||||
values.add(ns - 1)
|
||||
values.add(ns + 1)
|
||||
for ns in list(values):
|
||||
if (-ns) > PyTime_MAX:
|
||||
continue
|
||||
values.add(-ns)
|
||||
for ns in sorted(values):
|
||||
with self.subTest(ns=ns):
|
||||
self.assertEqual(_testcapi.PyTime_AsSecondsDouble(ns),
|
||||
ns_to_sec(ns))
|
||||
|
||||
def check_clock(self, c_func, py_func):
|
||||
t1 = c_func()
|
||||
t2 = py_func()
|
||||
self.assertAlmostEqual(t1, t2, delta=CLOCK_RES)
|
||||
|
||||
def test_monotonic(self):
|
||||
# Test PyTime_Monotonic() and PyTime_MonotonicRaw()
|
||||
self.check_clock(_testcapi.PyTime_Monotonic, time.monotonic)
|
||||
self.check_clock(_testcapi.PyTime_MonotonicRaw, time.monotonic)
|
||||
|
||||
def test_perf_counter(self):
|
||||
# Test PyTime_PerfCounter() and PyTime_PerfCounterRaw()
|
||||
self.check_clock(_testcapi.PyTime_PerfCounter, time.perf_counter)
|
||||
self.check_clock(_testcapi.PyTime_PerfCounterRaw, time.perf_counter)
|
||||
|
||||
def test_time(self):
|
||||
# Test PyTime_Time() and PyTime_TimeRaw()
|
||||
self.check_clock(_testcapi.PyTime_Time, time.time)
|
||||
self.check_clock(_testcapi.PyTime_TimeRaw, time.time)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
unittest.main()
|
Reference in New Issue
Block a user