Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

8327752: Convert javax/swing/JOptionPane/4174551/bug4174551.java applet to main #18228

Closed
wants to merge 3 commits into from
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
36 changes: 0 additions & 36 deletions test/jdk/javax/swing/JOptionPane/4174551/bug4174551.html

This file was deleted.

52 changes: 0 additions & 52 deletions test/jdk/javax/swing/JOptionPane/4174551/bug4174551.java

This file was deleted.

78 changes: 78 additions & 0 deletions test/jdk/javax/swing/JOptionPane/bug4174551.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
/*
* Copyright (c) 2001, 2024, 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
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/

/*
* @test
* @bug 4174551
* @summary JOptionPane should allow custom buttons
* @library /java/awt/regtesthelpers
* @build PassFailJFrame
* @run main/manual bug4174551
*/
import java.awt.FlowLayout;
import java.awt.Font;
import javax.swing.JDialog;
import javax.swing.JOptionPane;
import javax.swing.UIManager;

public class bug4174551 {
private static final String INSTRUCTIONS = """
Two Message Dialog should pop up side-by-side
one with a custom message font size 24 with message "HI 24"
and another with default optionpane message font size with message "HI default"
If custom message font size is not more than default message fontsize
AND
custom message buttonfont size is more than default message buttonfont size
press "Fail" else press "Pass". """;

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These instructions are so odd. How is the tester supposed to know the size they see ?
What can we do better ?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since this test is about support of custom button in optionpane
Test instructions updated for easier-to-understand pass-criteria with side-by-side optionpanes one with custom fontsize of 24 and another with default fontsize (guess it's 12) asking to verify if custom fontsize is more than default-fontsize

public static void main(String[] args) throws Exception {
PassFailJFrame.builder()
.title("JOptionPane Instructions")
.instructions(INSTRUCTIONS)
.rows(8)
.columns(40)
.testUI(bug4174551::createTestUI)
.build()
.awaitAndCheck();
}

private static JDialog createTestUI() {
JOptionPane defaultPane = new JOptionPane();
defaultPane.setMessage("HI default");
defaultPane.setMessageType(JOptionPane.INFORMATION_MESSAGE);
UIManager.getDefaults().put("OptionPane.buttonFont", new Font("Dialog", Font.PLAIN, 10));
UIManager.getDefaults().put("OptionPane.messageFont", new Font("Dialog", Font.PLAIN, 24));
JOptionPane optionPane = new JOptionPane();
optionPane.setMessage("HI 24!");
optionPane.setMessageType(JOptionPane.INFORMATION_MESSAGE);
JDialog dialog = new JDialog();
dialog.setLayout(new FlowLayout());
dialog.add(optionPane);
dialog.add(defaultPane);
dialog.pack();

System.out.println(UIManager.getDefaults().get("OptionPane.buttonFont"));
System.out.println(UIManager.getDefaults().get("OptionPane.messageFont"));
return dialog;
}
}