From cdbd91c2772f53927b65d309b0fdaa1ffbc5c964 Mon Sep 17 00:00:00 2001 From: "shahzaib.ibrahim" Date: Mon, 24 Jun 2024 11:53:20 +0200 Subject: [PATCH] Unit test writing for controls to test HiDpi Contributes to #62 and #127 --- .../eclipse/swt/widgets/WidgetWin32Tests.java | 216 +++++++++++++++++- .../win32/org/eclipse/swt/widgets/folder.png | Bin 0 -> 921 bytes 2 files changed, 214 insertions(+), 2 deletions(-) create mode 100644 bundles/org.eclipse.swt/Eclipse SWT Tests/win32/org/eclipse/swt/widgets/folder.png diff --git a/bundles/org.eclipse.swt/Eclipse SWT Tests/win32/org/eclipse/swt/widgets/WidgetWin32Tests.java b/bundles/org.eclipse.swt/Eclipse SWT Tests/win32/org/eclipse/swt/widgets/WidgetWin32Tests.java index d18726c6a20..af9063f716f 100644 --- a/bundles/org.eclipse.swt/Eclipse SWT Tests/win32/org/eclipse/swt/widgets/WidgetWin32Tests.java +++ b/bundles/org.eclipse.swt/Eclipse SWT Tests/win32/org/eclipse/swt/widgets/WidgetWin32Tests.java @@ -2,8 +2,13 @@ import static org.junit.Assert.assertEquals; +import java.io.*; + import org.eclipse.swt.*; +import org.eclipse.swt.graphics.*; import org.eclipse.swt.internal.*; +import org.eclipse.swt.internal.win32.*; +import org.eclipse.swt.layout.*; import org.junit.*; public class WidgetWin32Tests extends Win32AutoscaleTestBase { @@ -18,8 +23,215 @@ public void testWidgetZoomShouldChangeOnZoomLevelChange() { button.setText("Widget Test"); button.setBackground(shell.getDisplay().getSystemColor(SWT.COLOR_CYAN)); shell.open(); - assertEquals("The initial zoom is wrong", zoom, button.getZoom()); //pre-condition + assertEquals("The initial zoom is wrong", zoom, button.getZoom()); // pre-condition changeDPIZoom(scaledZoom); - assertEquals("The Zoom Level should be updated for button on zoom change event on its shell", scaledZoom, button.getZoom()); + assertEquals("The Zoom Level should be updated for button on zoom change event on its shell", scaledZoom, + button.getZoom()); + } + + @Test + public void testButtonPointsAfterZooming() throws NoSuchMethodException, IllegalAccessException { + shell = new Shell(display); + shell.setBounds(0, 0, 100, 160); + shell.setLayout(new FillLayout()); + shell.pack(); + + Button button = new Button(shell, SWT.PUSH); + button.setText("Button"); + button.setBounds(0, 0, 100, 200); + Point sizeBeforeEvent = button.getSize(); + Point p1 = button.computeSizeInPixels(sizeBeforeEvent.x, sizeBeforeEvent.y, false); + changeDPIZoom(200); + Point sizeAfterEvent = button.getSize(); + Point p2 = button.computeSizeInPixels(sizeAfterEvent.x, sizeAfterEvent.y, false); + + Assert.assertEquals("Width should be half in points after zooming to 200", p1.x, p2.x * 2); + Assert.assertEquals("Height should be half in points after zooming to 200", p1.y, p2.y * 2); + } + + @Test + public void testImagePixelsWithDoubleZoomLevel() { + InputStream inputStream = WidgetWin32Tests.class.getResourceAsStream("folder.png"); + Image image = new Image(display, inputStream); + + Point buttonImageSizeBeforeEvent = getImageDimension(image, 100); + Point buttonImageSizeAfterEvent = getImageDimension(image, 200); + + Assert.assertEquals("Width of a button image should be doubled after zooming to 200", + buttonImageSizeBeforeEvent.x * 2, buttonImageSizeAfterEvent.x); + Assert.assertEquals("Height of a button image should be doubled after zooming to 200", + buttonImageSizeBeforeEvent.y * 2, buttonImageSizeAfterEvent.y); + } + + public Point getImageDimension(Image image, Integer zoomLevel) { + BITMAP bm = new BITMAP(); + OS.GetObject(Image.win32_getHandle(image, zoomLevel), BITMAP.sizeof, bm); + int imgWidth = bm.bmWidth; + int imgHeight = bm.bmHeight; + return new Point(imgWidth, imgHeight); + } + + @Test + public void testButtonFontAfterZooming() { + shell = new Shell(display); + shell.setBounds(0, 0, 100, 160); + shell.setLayout(new FillLayout()); + shell.pack(); + + Button button = new Button(shell, SWT.PUSH); + button.setText("Button"); + button.setBounds(0, 0, 100, 200); + Font font = new Font(display, "Arial", 12, SWT.BOLD); + button.setFont(font); + + int heightBeforeZoom = button.getFont().getFontData()[0].data.lfHeight; + changeDPIZoom(200); + int heightAfterZoom = button.getFont().getFontData()[0].data.lfHeight; + + Assert.assertEquals("Height of a font of the button should be doubled after zooming to 200", + heightBeforeZoom * 2, heightAfterZoom); } + + @Test + public void testCoolItemAfterZooming() { + shell = new Shell(display); + shell.setBounds(0, 0, 100, 160); + shell.setLayout(new FillLayout()); + shell.pack(); + + CoolBar coolBar = new CoolBar(shell, SWT.NONE); + CoolItem item1 = new CoolItem(coolBar, SWT.NONE); + Label label1 = new Label(coolBar, SWT.NONE); + label1.setText("Label 1"); + item1.setControl(label1); + item1.setPreferredSize(label1.computeSize(SWT.DEFAULT, SWT.DEFAULT)); + item1.setSize(item1.getPreferredSize()); + + var preferredControlSize = item1.getPreferredSizeInPixels(); + int xBeforeZoom = preferredControlSize.x; + int yBeforeZoom = preferredControlSize.y; + changeDPIZoom(200); + var preferredControlSize2 = item1.getPreferredSizeInPixels(); + int xAfterZoom = preferredControlSize2.x; + int yAfterZoom = preferredControlSize2.y; + + Assert.assertTrue("Height of a Item should be greater after zooming to 200", xBeforeZoom < xAfterZoom); + Assert.assertTrue("Width of a Item should be greater after zooming to 200", yBeforeZoom < yAfterZoom); + } + + @Test + public void testExpandItemAfterZooming() { + shell = new Shell(display); + shell.setBounds(0, 0, 100, 160); + shell.setLayout(new FillLayout()); + shell.pack(); + + ExpandBar coolBar = new ExpandBar(shell, SWT.NONE); + ExpandItem item1 = new ExpandItem(coolBar, SWT.NONE); + Label label1 = new Label(coolBar, SWT.NONE); + label1.setText("Label 1"); + item1.setControl(label1); + item1.setHeight(10); + item1.setExpanded(true); + + var heightBeforeZoom = item1.getHeightInPixels(); + changeDPIZoom(200); + var heightAfterZoom = item1.getHeightInPixels(); + + Assert.assertEquals("Height of a font of the button should be doubled after zooming to 200", + heightBeforeZoom * 2, heightAfterZoom); + } + + @Test + public void testTabFolderSizeAfterZooming() { + shell = new Shell(display); + shell.setBounds(0, 0, 100, 160); + shell.setLayout(new FillLayout()); + shell.pack(); + + TabFolder tabFolder = new TabFolder(shell, SWT.NONE); + tabFolder.setBounds(20, 20, 360, 240); + + TabItem tabItem = new TabItem(tabFolder, SWT.NONE); + tabItem.setText("Tab 1"); + Label label = new Label(tabFolder, SWT.NONE); + label.setSize(200, 200); + tabItem.setControl(label); + + Point tabItemSizeBeforeEvent = tabItem.getControl().getSize(); + changeDPIZoom(200); + Point tabItemSizeAfterEvent = tabItem.getControl().getSize(); + + Assert.assertEquals("Width of a tab folder item should be halved in points after zooming to 200", + tabItemSizeBeforeEvent.x, tabItemSizeAfterEvent.x * 2); + Assert.assertEquals("Height of a tab folder item should be halved in points after zooming to 200", + tabItemSizeBeforeEvent.y, tabItemSizeAfterEvent.y * 2); + } + + @Test + public void testTableAfterZooming() { + shell = new Shell(display); + shell.setBounds(0, 0, 100, 160); + shell.setLayout(new FillLayout()); + shell.pack(); + + Table table = new Table(shell, SWT.BORDER | SWT.V_SCROLL | SWT.H_SCROLL); + table.setBounds(20, 20, 360, 240); + table.setHeaderVisible(true); + table.setLinesVisible(true); + + TableColumn column = new TableColumn(table, SWT.NONE); + column.setText("Column 1"); + column.setWidth(200); + + Font font = new Font(display, "Arial", 12, SWT.BOLD); + + TableItem item1 = new TableItem(table, SWT.NONE); + item1.setText("Item 1"); + item1.setFont(font); + + for (TableColumn col : table.getColumns()) { + col.pack(); + } + + int fontHeightBefore = item1.getFont().getFontData()[0].data.lfHeight; + changeDPIZoom(200); + int fontHeightAfter = item1.getFont().getFontData()[0].data.lfHeight; + + Assert.assertEquals("Height of a font for table item should be doubled after zooming to 200", + fontHeightBefore * 2, fontHeightAfter); + } + + @Test + public void testTreeAfterZooming() { + shell = new Shell(display); + shell.setBounds(0, 0, 100, 160); + shell.setLayout(new FillLayout()); + shell.pack(); + + Tree tree = new Tree(shell, SWT.BORDER | SWT.V_SCROLL | SWT.H_SCROLL); + tree.setBounds(20, 20, 360, 240); + tree.setHeaderVisible(true); + tree.setLinesVisible(true); + + TreeColumn column = new TreeColumn(tree, SWT.NONE); + column.setText("Column 1"); + column.setWidth(200); + + Font font = new Font(display, "Arial", 12, SWT.BOLD); + TreeItem item1 = new TreeItem(tree, SWT.NONE); + item1.setText("Item 1"); + item1.setFont(font); + for (TreeColumn col : tree.getColumns()) { + col.pack(); + } + + int fontHeightBefore = item1.getFont().getFontData()[0].data.lfHeight; + changeDPIZoom(200); + int fontHeightAfter = item1.getFont().getFontData()[0].data.lfHeight; + + Assert.assertEquals("Height of a font for tree item should be doubled after zooming to 200", + fontHeightBefore * 2, fontHeightAfter); + } + } diff --git a/bundles/org.eclipse.swt/Eclipse SWT Tests/win32/org/eclipse/swt/widgets/folder.png b/bundles/org.eclipse.swt/Eclipse SWT Tests/win32/org/eclipse/swt/widgets/folder.png new file mode 100644 index 0000000000000000000000000000000000000000..9ef2dc09d251e60441525a62ae41076bcd4bdd5b GIT binary patch literal 921 zcmXX^KZxHo9DULX?a`LQsdj2hK!`4GI{7=f!v;z@q;C)kt^dYg!5f@PkQS74XfruD z$O%&3(4j+yn|{zia1d??EyUs6PH@nz+cRHi;C()yyqA3P$tU@K_r^!(H!f`eIG?U< ze?0vg3(lOH_S4OKUjnDFd;R9loR&EjJMqeugdF zurCS`7y}tt0u|T;9f-u3$i$MU#GdFxWX4QpmP}>#OlP7pRZbtr`B#EtFoR35f_t!oksOnmT#}XClbww0n9b~xt?ZudY*fc;R+nm3_i9(8IX1Jo zG^@EcyBWiAn8RgQ!+qG3nO&O&+1)-lIXOByIy^i)I5^nf-{0HYd+XNQcjn`ty?gDG zuYn8C7QFV`SC7A#*hB