Unit test for alert width (#1307)
	
		
	
				
					
				
			* unit test for alert width * fix scale * comment * fix offending alert text * rename * update process replay refs Co-authored-by: Willem Melching <willem.melching@gmail.com>pull/49/head
							parent
							
								
									017b1f6770
								
							
						
					
					
						commit
						0f6c22ce8b
					
				
				 3 changed files with 53 additions and 5 deletions
			
			
		| @ -0,0 +1,48 @@ | ||||
| #!/usr/bin/env python3 | ||||
| import os | ||||
| import unittest | ||||
| from PIL import Image, ImageDraw, ImageFont | ||||
| 
 | ||||
| from cereal import log | ||||
| from common.basedir import BASEDIR | ||||
| from selfdrive.controls.lib.alerts import ALERTS | ||||
| 
 | ||||
| AlertSize = log.ControlsState.AlertSize | ||||
| 
 | ||||
| FONT_PATH = os.path.join(BASEDIR, "selfdrive/assets/fonts") | ||||
| REGULAR_FONT_PATH = os.path.join(FONT_PATH, "opensans_semibold.ttf") | ||||
| BOLD_FONT_PATH = os.path.join(FONT_PATH, "opensans_semibold.ttf") | ||||
| SEMIBOLD_FONT_PATH = os.path.join(FONT_PATH, "opensans_semibold.ttf") | ||||
| 
 | ||||
| MAX_TEXT_WIDTH = 1920 - 300 # full screen width is useable, minus sidebar | ||||
| # TODO: get exact scale factor. found this empirically, works well enough | ||||
| FONT_SIZE_SCALE = 1.85 # factor to scale from nanovg units to PIL | ||||
| 
 | ||||
| class TestAlerts(unittest.TestCase): | ||||
| 
 | ||||
|   # ensure alert text doesn't exceed allowed width | ||||
|   def test_alert_text_length(self): | ||||
|     draw = ImageDraw.Draw(Image.new('RGB', (0, 0))) | ||||
| 
 | ||||
|     fonts = { | ||||
|             AlertSize.small: [ImageFont.truetype(SEMIBOLD_FONT_PATH, int(40*FONT_SIZE_SCALE))], | ||||
|             AlertSize.mid: [ImageFont.truetype(BOLD_FONT_PATH, int(48*FONT_SIZE_SCALE)), | ||||
|                               ImageFont.truetype(REGULAR_FONT_PATH, int(36*FONT_SIZE_SCALE))], | ||||
|             } | ||||
| 
 | ||||
|     for alert in ALERTS: | ||||
|       # for full size alerts, both text fields wrap the text, | ||||
|       # so it's unlikely that they  would go past the max width | ||||
|       if alert.alert_size in [AlertSize.none, AlertSize.full]: | ||||
|         continue | ||||
| 
 | ||||
|       for i, txt in enumerate([alert.alert_text_1, alert.alert_text_2]): | ||||
|         if i >= len(fonts[alert.alert_size]): break | ||||
| 
 | ||||
|         font = fonts[alert.alert_size][i] | ||||
|         w, h = draw.textsize(txt, font) | ||||
|         msg = "type: %s msg: %s" % (alert.alert_type, txt) | ||||
|         self.assertLessEqual(w, MAX_TEXT_WIDTH, msg=msg) | ||||
| 
 | ||||
| if __name__ == "__main__": | ||||
|   unittest.main() | ||||
| @ -1 +1 @@ | ||||
| 852b5b42981cf17a18c7eebc9b501db2f5b0c33b | ||||
| 852b5b42981cf17a18c7eebc9b501db2f5b0c33b | ||||
					Loading…
					
					
				
		Reference in new issue