You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					64 lines
				
				1.8 KiB
			
		
		
			
		
	
	
					64 lines
				
				1.8 KiB
			| 
											5 years ago
										 | #!/usr/bin/env python3
 | ||
|  | 
 | ||
|  | import time
 | ||
|  | import unittest
 | ||
|  | 
 | ||
|  | import cereal.messaging as messaging
 | ||
| 
											3 years ago
										 | from system.hardware import TICI
 | ||
| 
											5 years ago
										 | from selfdrive.test.helpers import with_processes
 | ||
|  | 
 | ||
| 
											5 years ago
										 | TEST_TIMESPAN = 30 # random.randint(60, 180) # seconds
 | ||
| 
											5 years ago
										 | SKIP_FRAME_TOLERANCE = 0
 | ||
| 
											5 years ago
										 | LAG_FRAME_TOLERANCE = 2 # ms
 | ||
| 
											5 years ago
										 | 
 | ||
|  | FPS_BASELINE = 20
 | ||
|  | CAMERAS = {
 | ||
| 
											5 years ago
										 |   "roadCameraState": FPS_BASELINE,
 | ||
|  |   "driverCameraState": FPS_BASELINE // 2,
 | ||
| 
											5 years ago
										 | }
 | ||
|  | 
 | ||
|  | if TICI:
 | ||
| 
											5 years ago
										 |   CAMERAS["driverCameraState"] = FPS_BASELINE
 | ||
|  |   CAMERAS["wideRoadCameraState"] = FPS_BASELINE
 | ||
| 
											5 years ago
										 | 
 | ||
|  | class TestCamerad(unittest.TestCase):
 | ||
|  |   @classmethod
 | ||
|  |   def setUpClass(cls):
 | ||
| 
											4 years ago
										 |     if not TICI:
 | ||
| 
											5 years ago
										 |       raise unittest.SkipTest
 | ||
|  | 
 | ||
|  |   @with_processes(['camerad'])
 | ||
|  |   def test_frame_packets(self):
 | ||
|  |     print("checking frame pkts continuity")
 | ||
|  |     print(TEST_TIMESPAN)
 | ||
|  | 
 | ||
|  |     sm = messaging.SubMaster([socket_name for socket_name in CAMERAS])
 | ||
|  | 
 | ||
|  |     last_frame_id = dict.fromkeys(CAMERAS, None)
 | ||
| 
											5 years ago
										 |     last_ts = dict.fromkeys(CAMERAS, None)
 | ||
|  |     start_time_sec = time.time()
 | ||
|  |     while time.time()- start_time_sec < TEST_TIMESPAN:
 | ||
| 
											5 years ago
										 |       sm.update()
 | ||
|  | 
 | ||
|  |       for camera in CAMERAS:
 | ||
|  |         if sm.updated[camera]:
 | ||
| 
											5 years ago
										 |           ct = (sm[camera].timestampEof if not TICI else sm[camera].timestampSof) / 1e6
 | ||
|  |           if last_frame_id[camera] is None:
 | ||
|  |             last_frame_id[camera] = sm[camera].frameId
 | ||
|  |             last_ts[camera] = ct
 | ||
| 
											5 years ago
										 |             continue
 | ||
| 
											5 years ago
										 | 
 | ||
| 
											5 years ago
										 |           dfid = sm[camera].frameId - last_frame_id[camera]
 | ||
| 
											5 years ago
										 |           self.assertTrue(abs(dfid - 1) <= SKIP_FRAME_TOLERANCE, "%s frame id diff is %d" % (camera, dfid))
 | ||
|  | 
 | ||
|  |           dts = ct - last_ts[camera]
 | ||
| 
											4 years ago
										 |           self.assertTrue(abs(dts - (1000/CAMERAS[camera])) < LAG_FRAME_TOLERANCE, f"{camera} frame t(ms) diff is {dts:f}")
 | ||
| 
											5 years ago
										 | 
 | ||
| 
											5 years ago
										 |           last_frame_id[camera] = sm[camera].frameId
 | ||
| 
											5 years ago
										 |           last_ts[camera] = ct
 | ||
| 
											5 years ago
										 | 
 | ||
|  |       time.sleep(0.01)
 | ||
|  | 
 | ||
|  | if __name__ == "__main__":
 | ||
|  |   unittest.main()
 |