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>
old-commit-hash: 0f6c22ce8b
			
			
				vw-mqb-aeb
			
			
		
							parent
							
								
									907a97f1ee
								
							
						
					
					
						commit
						d4cec82895
					
				
				 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