fix wrong `Label.frame_body.x2` value (#2134)
* fix wrong `Label.frame_body.x2` value `update_scroll_inset` might change `frame_inset`, i.e. we need to `computeFrame` with the new values. * add tests for Label * add missing `local`, remove code in comments * move `TestFramedScreen` outside test functionsdevelop
							parent
							
								
									add8aa2386
								
							
						
					
					
						commit
						07f54deb0b
					
				| @ -0,0 +1,94 @@ | ||||
| -- test -dhack/scripts/devel/tests -twidgets.Label | ||||
| 
 | ||||
| local gui = require('gui') | ||||
| local widgets = require('gui.widgets') | ||||
| 
 | ||||
| local xtest = {} -- use to temporarily disable tests (change `function xtest.somename` to `function xxtest.somename`) | ||||
| local wait = function(n) | ||||
|     delay(n or 30) -- enable for debugging the tests | ||||
| end | ||||
| 
 | ||||
| local fs = defclass(fs, gui.FramedScreen) | ||||
| fs.ATTRS = { | ||||
|     frame_style = gui.GREY_LINE_FRAME, | ||||
|     frame_title = 'TestFramedScreen', | ||||
|     frame_width = 10, | ||||
|     frame_height = 10, | ||||
|     frame_inset = 0, | ||||
|     focus_path = 'test-framed-screen', | ||||
| } | ||||
| 
 | ||||
| function test.Label_correct_frame_body_with_scroll_icons() | ||||
|     local t = {} | ||||
|     for i = 1, 12 do | ||||
|         t[#t+1] = tostring(i) | ||||
|         t[#t+1] = NEWLINE | ||||
|     end | ||||
| 
 | ||||
|     function fs:init(args) | ||||
|         self:addviews{ | ||||
|             widgets.Label{ | ||||
|                 view_id = 'text', | ||||
|                 frame_inset = 0, | ||||
|                 text = t, | ||||
|                 --show_scroll_icons = 'right', | ||||
|             }, | ||||
|         } | ||||
|     end | ||||
| 
 | ||||
|     local o = fs{} | ||||
|     --o:show() | ||||
|     --wait() | ||||
|     expect.eq(o.subviews.text.frame_body.width, 9, "Label's frame_body.x2 and .width should be one smaller because of show_scroll_icons.") | ||||
|     --o:dismiss() | ||||
| end | ||||
| 
 | ||||
| function test.Label_correct_frame_body_with_few_text_lines() | ||||
|     local t = {} | ||||
|     for i = 1, 10 do | ||||
|         t[#t+1] = tostring(i) | ||||
|         t[#t+1] = NEWLINE | ||||
|     end | ||||
| 
 | ||||
|     function fs:init(args) | ||||
|         self:addviews{ | ||||
|             widgets.Label{ | ||||
|                 view_id = 'text', | ||||
|                 frame_inset = 0, | ||||
|                 text = t, | ||||
|                 --show_scroll_icons = 'right', | ||||
|             }, | ||||
|         } | ||||
|     end | ||||
| 
 | ||||
|     local o = fs{} | ||||
|     --o:show() | ||||
|     --wait() | ||||
|     expect.eq(o.subviews.text.frame_body.width, 10, "Label's frame_body.x2 and .width should not change with show_scroll_icons = false.") | ||||
|     --o:dismiss() | ||||
| end | ||||
| 
 | ||||
| function test.Label_correct_frame_body_without_show_scroll_icons() | ||||
|     local t = {} | ||||
|     for i = 1, 12 do | ||||
|         t[#t+1] = tostring(i) | ||||
|         t[#t+1] = NEWLINE | ||||
|     end | ||||
| 
 | ||||
|     function fs:init(args) | ||||
|         self:addviews{ | ||||
|             widgets.Label{ | ||||
|                 view_id = 'text', | ||||
|                 frame_inset = 0, | ||||
|                 text = t, | ||||
|                 show_scroll_icons = false, | ||||
|             }, | ||||
|         } | ||||
|     end | ||||
| 
 | ||||
|     local o = fs{} | ||||
|     --o:show() | ||||
|     --wait() | ||||
|     expect.eq(o.subviews.text.frame_body.width, 10, "Label's frame_body.x2 and .width should not change with show_scroll_icons = false.") | ||||
|     --o:dismiss() | ||||
| end | ||||
		Loading…
	
		Reference in New Issue