From 4ee5f65691ac210b043c14f88472bac382dadd69 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Thu, 25 Apr 2019 15:15:53 -0700 Subject: [PATCH] 8214046: [macosx] Undecorated Frame does not Iconify when set to Reviewed-by: dmarkov --- .../macosx/native/libawt_lwawt/awt/AWTWindow.m | 2 +- .../NormalToIconifiedTest.java | 17 ++++++++++------- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTWindow.m b/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTWindow.m index 88932de79b9..da65d8d36e4 100644 --- a/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTWindow.m +++ b/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTWindow.m @@ -205,13 +205,13 @@ AWT_NS_WINDOW_IMPLEMENTATION if (IS(styleBits, DECORATED)) { type |= NSTitledWindowMask; if (IS(styleBits, CLOSEABLE)) type |= NSClosableWindowMask; - if (IS(styleBits, MINIMIZABLE)) type |= NSMiniaturizableWindowMask; if (IS(styleBits, RESIZABLE)) type |= NSResizableWindowMask; if (IS(styleBits, FULL_WINDOW_CONTENT)) type |= NSFullSizeContentViewWindowMask; } else { type |= NSBorderlessWindowMask; } + if (IS(styleBits, MINIMIZABLE)) type |= NSMiniaturizableWindowMask; if (IS(styleBits, TEXTURED)) type |= NSTexturedBackgroundWindowMask; if (IS(styleBits, UNIFIED)) type |= NSUnifiedTitleAndToolbarWindowMask; if (IS(styleBits, UTILITY)) type |= NSUtilityWindowMask; diff --git a/test/jdk/java/awt/Frame/NormalToIconified/NormalToIconifiedTest.java b/test/jdk/java/awt/Frame/NormalToIconified/NormalToIconifiedTest.java index 5daa763c572..0523d164fb6 100644 --- a/test/jdk/java/awt/Frame/NormalToIconified/NormalToIconifiedTest.java +++ b/test/jdk/java/awt/Frame/NormalToIconified/NormalToIconifiedTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /** * @test * @key headful - * @bug 8171949 + * @bug 8171949 8214046 * @summary Tests that bitwise mask is set and state listener is notified during state transition. * @author Dmitry Markov * @library ../../regtesthelpers @@ -41,12 +41,18 @@ import java.util.concurrent.atomic.AtomicBoolean; import test.java.awt.regtesthelpers.Util; public class NormalToIconifiedTest { - private static final AtomicBoolean listenerNotified = new AtomicBoolean(false); public static void main(String[] args) { - Robot robot = Util.createRobot(); + test(false); + test(true); + } + private static void test(final boolean undecorated) { + AtomicBoolean listenerNotified = new AtomicBoolean(false); + + Robot robot = Util.createRobot(); Frame testFrame = new Frame("Test Frame"); + testFrame.setUndecorated(undecorated); testFrame.setSize(200, 200); testFrame.addWindowStateListener(new WindowStateListener() { @Override @@ -58,14 +64,11 @@ public class NormalToIconifiedTest { } }); testFrame.setVisible(true); - Frame mainFrame = new Frame("Main Frame"); mainFrame.setSize(200, 200); mainFrame.setLocationRelativeTo(null); mainFrame.setVisible(true); - Util.waitForIdle(robot); - try { Util.clickOnComp(mainFrame, robot); Util.waitForIdle(robot);