updated usage of time.time to time.monotonic or time.perf_counter due to time.time possibly rolling backwards

This commit is contained in:
Blake Harnden 2019-12-06 09:42:41 -08:00
parent b9bbf397c9
commit 45a23a6c14
11 changed files with 29 additions and 29 deletions

View file

@ -411,7 +411,7 @@ class CoreClient:
else: else:
emane_config = None emane_config = None
start = time.time() start = time.perf_counter()
response = self.client.start_session( response = self.client.start_session(
self.session_id, self.session_id,
nodes, nodes,
@ -425,7 +425,7 @@ class CoreClient:
service_configs, service_configs,
file_configs, file_configs,
) )
process_time = time.time() - start process_time = time.perf_counter() - start
logging.debug("start session(%s), result: %s", self.session_id, response.result) logging.debug("start session(%s), result: %s", self.session_id, response.result)
self.app.statusbar.start_session_callback(process_time) self.app.statusbar.start_session_callback(process_time)
@ -439,9 +439,9 @@ class CoreClient:
def stop_session(self, session_id=None): def stop_session(self, session_id=None):
if not session_id: if not session_id:
session_id = self.session_id session_id = self.session_id
start = time.time() start = time.perf_counter()
response = self.client.stop_session(session_id) response = self.client.stop_session(session_id)
process_time = time.time() - start process_time = time.perf_counter() - start
self.app.statusbar.stop_session_callback(process_time) self.app.statusbar.stop_session_callback(process_time)
logging.debug("stopped session(%s), result: %s", session_id, response.result) logging.debug("stopped session(%s), result: %s", session_id, response.result)

View file

@ -33,10 +33,10 @@ class MenuAction:
def cleanup_old_session(self, quitapp=False): def cleanup_old_session(self, quitapp=False):
logging.info("cleaning up old session") logging.info("cleaning up old session")
start = time.time() start = time.perf_counter()
self.app.core.stop_session() self.app.core.stop_session()
self.app.core.delete_session() self.app.core.delete_session()
process_time = time.time() - start process_time = time.perf_counter() - start
self.app.statusbar.stop_session_callback(process_time) self.app.statusbar.stop_session_callback(process_time)
if quitapp: if quitapp:
self.app.quit() self.app.quit()

View file

@ -660,7 +660,7 @@ class CoreGrpcServer(core_pb2_grpc.CoreApiServicer):
last_check = None last_check = None
last_stats = None last_stats = None
while self._is_running(context): while self._is_running(context):
now = time.time() now = time.monotonic()
stats = get_net_stats() stats = get_net_stats()
# calculate average # calculate average

View file

@ -1710,7 +1710,7 @@ class CoreHandler(socketserver.BaseRequestHandler):
event_type=event_type, event_type=event_type,
name=name, name=name,
data=fail_data + ";" + unknown_data, data=fail_data + ";" + unknown_data,
time=str(time.time()), time=str(time.monotonic()),
) )
self.session.broadcast_event(event_data) self.session.broadcast_event(event_data)

View file

@ -103,7 +103,7 @@ class Session:
# TODO: should the default state be definition? # TODO: should the default state be definition?
self.state = EventTypes.NONE.value self.state = EventTypes.NONE.value
self._state_time = time.time() self._state_time = time.monotonic()
self._state_file = os.path.join(self.session_dir, "state") self._state_file = os.path.join(self.session_dir, "state")
# hooks handlers # hooks handlers
@ -1030,7 +1030,7 @@ class Session:
return return
self.state = state_value self.state = state_value
self._state_time = time.time() self._state_time = time.monotonic()
logging.info("changing session(%s) to state %s", self.id, state_name) logging.info("changing session(%s) to state %s", self.id, state_name)
self.write_state(state_value) self.write_state(state_value)
@ -1038,7 +1038,7 @@ class Session:
self.run_state_hooks(state_value) self.run_state_hooks(state_value)
if send_event: if send_event:
event_data = EventData(event_type=state_value, time=str(time.time())) event_data = EventData(event_type=state_value, time=str(time.monotonic()))
self.broadcast_event(event_data) self.broadcast_event(event_data)
def write_state(self, state): def write_state(self, state):
@ -1821,7 +1821,7 @@ class Session:
if not in runtime. if not in runtime.
""" """
if self.state == EventTypes.RUNTIME_STATE.value: if self.state == EventTypes.RUNTIME_STATE.value:
return time.time() - self._state_time return time.monotonic() - self._state_time
else: else:
return 0.0 return 0.0

View file

@ -145,7 +145,7 @@ class EventLoop:
with self.lock: with self.lock:
if not self.running or not self.queue: if not self.running or not self.queue:
break break
now = time.time() now = time.monotonic()
if self.queue[0].time > now: if self.queue[0].time > now:
schedule = True schedule = True
break break
@ -170,7 +170,7 @@ class EventLoop:
raise ValueError("scheduling event while not running") raise ValueError("scheduling event while not running")
if not self.queue: if not self.queue:
return return
delay = self.queue[0].time - time.time() delay = self.queue[0].time - time.monotonic()
if self.timer: if self.timer:
raise ValueError("timer was already set") raise ValueError("timer was already set")
self.timer = Timer(delay, self.__run_events) self.timer = Timer(delay, self.__run_events)
@ -187,7 +187,7 @@ class EventLoop:
if self.running: if self.running:
return return
self.running = True self.running = True
self.start = time.time() self.start = time.monotonic()
for event in self.queue: for event in self.queue:
event.time += self.start event.time += self.start
self.__schedule_event() self.__schedule_event()
@ -225,7 +225,7 @@ class EventLoop:
self.eventnum += 1 self.eventnum += 1
evtime = float(delaysec) evtime = float(delaysec)
if self.running: if self.running:
evtime += time.time() evtime += time.monotonic()
event = Event(eventnum, evtime, func, *args, **kwds) event = Event(eventnum, evtime, func, *args, **kwds)
if self.queue: if self.queue:

View file

@ -174,7 +174,7 @@ class MobilityManager(ModelManager):
event_type=event_type, event_type=event_type,
name=f"mobility:{model.name}", name=f"mobility:{model.name}",
data=data, data=data,
time=str(time.time()), time=str(time.monotonic()),
) )
self.session.broadcast_event(event_data) self.session.broadcast_event(event_data)
@ -612,7 +612,7 @@ class WayPointMobility(WirelessModel):
if self.state != self.STATE_RUNNING: if self.state != self.STATE_RUNNING:
return return
t = self.lasttime t = self.lasttime
self.lasttime = time.time() self.lasttime = time.monotonic()
now = self.lasttime - self.timezero now = self.lasttime - self.timezero
dt = self.lasttime - t dt = self.lasttime - t
@ -664,7 +664,7 @@ class WayPointMobility(WirelessModel):
:return: nothing :return: nothing
""" """
logging.info("running mobility scenario") logging.info("running mobility scenario")
self.timezero = time.time() self.timezero = time.monotonic()
self.lasttime = self.timezero - (0.001 * self.refresh_ms) self.lasttime = self.timezero - (0.001 * self.refresh_ms)
self.movenodesinitial() self.movenodesinitial()
self.runround() self.runround()
@ -844,7 +844,7 @@ class WayPointMobility(WirelessModel):
self.lasttime = 0 self.lasttime = 0
self.run() self.run()
elif laststate == self.STATE_PAUSED: elif laststate == self.STATE_PAUSED:
now = time.time() now = time.monotonic()
self.timezero += now - self.lasttime self.timezero += now - self.lasttime
self.lasttime = now - (0.001 * self.refresh_ms) self.lasttime = now - (0.001 * self.refresh_ms)
self.runround() self.runround()
@ -871,7 +871,7 @@ class WayPointMobility(WirelessModel):
:return: nothing :return: nothing
""" """
self.state = self.STATE_PAUSED self.state = self.STATE_PAUSED
self.lasttime = time.time() self.lasttime = time.monotonic()
class Ns2ScriptedMobility(WayPointMobility): class Ns2ScriptedMobility(WayPointMobility):

View file

@ -57,7 +57,7 @@ class EbtablesQueue:
:return: nothing :return: nothing
""" """
with self.updatelock: with self.updatelock:
self.last_update_time[wlan] = time.time() self.last_update_time[wlan] = time.monotonic()
if self.doupdateloop: if self.doupdateloop:
return return
@ -108,9 +108,9 @@ class EbtablesQueue:
:rtype: float :rtype: float
""" """
try: try:
elapsed = time.time() - self.last_update_time[wlan] elapsed = time.monotonic() - self.last_update_time[wlan]
except KeyError: except KeyError:
self.last_update_time[wlan] = time.time() self.last_update_time[wlan] = time.monotonic()
elapsed = 0.0 elapsed = 0.0
return elapsed return elapsed
@ -122,7 +122,7 @@ class EbtablesQueue:
:param wlan: wlan entity :param wlan: wlan entity
:return: nothing :return: nothing
""" """
self.last_update_time[wlan] = time.time() self.last_update_time[wlan] = time.monotonic()
self.updates.remove(wlan) self.updates.remove(wlan)
def updateloop(self): def updateloop(self):

View file

@ -538,13 +538,13 @@ class CoreServices:
time.sleep(service.validation_timer) time.sleep(service.validation_timer)
# non-blocking, attempt to validate periodically, up to validation_timer time # non-blocking, attempt to validate periodically, up to validation_timer time
elif service.validation_mode == ServiceMode.NON_BLOCKING: elif service.validation_mode == ServiceMode.NON_BLOCKING:
start = time.time() start = time.monotonic()
while True: while True:
status = self.validate_service(node, service) status = self.validate_service(node, service)
if not status: if not status:
break break
if time.time() - start > service.validation_timer: if time.monotonic() - start > service.validation_timer:
break break
time.sleep(service.validation_period) time.sleep(service.validation_period)

View file

@ -1042,7 +1042,7 @@ class TestGrpc:
client.events(session.id, handle_event) client.events(session.id, handle_event)
time.sleep(0.1) time.sleep(0.1)
event = EventData( event = EventData(
event_type=EventTypes.RUNTIME_STATE.value, time=str(time.time()) event_type=EventTypes.RUNTIME_STATE.value, time=str(time.monotonic())
) )
session.broadcast_event(event) session.broadcast_event(event)

View file

@ -523,7 +523,7 @@ class TestGui:
MessageFlags.ADD.value, MessageFlags.ADD.value,
[ [
(EventTlvs.TYPE, EventTypes.SCHEDULED.value), (EventTlvs.TYPE, EventTypes.SCHEDULED.value),
(EventTlvs.TIME, str(time.time() + 100)), (EventTlvs.TIME, str(time.monotonic() + 100)),
(EventTlvs.NODE, node.id), (EventTlvs.NODE, node.id),
(EventTlvs.NAME, "event"), (EventTlvs.NAME, "event"),
(EventTlvs.DATA, "data"), (EventTlvs.DATA, "data"),