8160438: javax/swing/plaf/nimbus/8057791/bug8057791.java fails

Reviewed-by: alexsch, rchamyal
This commit is contained in:
Avik Niyogi 2016-07-20 11:25:57 +05:30
parent 799f4aec1e
commit b86418d365

View File

@ -22,19 +22,19 @@
*/
/* @test
@bug 8057791
@bug 8057791 8160438
@summary Selection in JList is drawn with wrong colors in Nimbus L&F
@author Anton Litvinov
@run main bug8057791
*/
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.Robot;
import java.awt.image.BufferedImage;
import java.lang.reflect.InvocationTargetException;
import java.util.HashSet;
import javax.swing.DefaultListModel;
import javax.swing.JFrame;
import javax.swing.JList;
import javax.swing.SwingUtilities;
import javax.swing.UIManager;
@ -42,59 +42,148 @@ import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.plaf.nimbus.NimbusLookAndFeel;
public class bug8057791 {
public static void main(String[] args) {
private static JFrame frame;
private static JList<String> list;
private static DefaultListModel<String> model;
private static Robot robot;
private static final int SELECTED_INDEX = 0;
private static volatile String errorString = "";
public static void main(String[] args) throws Exception {
robot = new Robot();
robot.waitForIdle();
runSteps();
if (!errorString.isEmpty()) {
throw new RuntimeException("Error Log:\n" + errorString);
}
}
private static void runSteps() throws Exception {
if (tryNimbusLookAndFeel()) {
createUI();
robot.waitForIdle();
runColorTestCase();
robot.waitForIdle();
cleanUp();
}
}
private static boolean tryNimbusLookAndFeel()
throws Exception {
try {
UIManager.setLookAndFeel(new NimbusLookAndFeel());
} catch (UnsupportedLookAndFeelException e) {
errorString += e.getMessage();
return false;
}
return true;
}
private static void createUI()
throws Exception {
SwingUtilities.invokeAndWait(new Runnable() {
@Override
public void run() {
final int listWidth = 50;
final int listHeight = 50;
final int selCellIndex = 0;
frame = new JFrame();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
list = new JList<>();
model = new DefaultListModel<>();
model.add(0, "@@");
Font font = list.getFont();
list.setFont(
new Font(font.getFontName(),
Font.BOLD,
(int) (font.getSize2D() * 2)));
list.setModel(model);
list.setSelectedIndex(SELECTED_INDEX);
frame.add(list);
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
});
}
JList<String> list = new JList<String>();
list.setSize(listWidth, listHeight);
DefaultListModel<String> listModel = new DefaultListModel<String>();
listModel.add(selCellIndex, "E");
list.setModel(listModel);
list.setSelectedIndex(selCellIndex);
private static void runColorTestCase() throws Exception {
SwingUtilities.invokeAndWait(new Runnable() {
@Override
public void run() {
Rectangle cellBounds = list.getCellBounds(SELECTED_INDEX, SELECTED_INDEX);
cellBounds.x += list.getLocationOnScreen().x;
cellBounds.y += list.getLocationOnScreen().y;
//positive test cases
Color foregroundColor = list.getSelectionForeground();
Color backgroundColor = list.getSelectionBackground();
checkColor(foregroundColor, cellBounds);
checkColor(backgroundColor, cellBounds);
//negative test cases
Color changedForegroundColor = foregroundColor.darker();
Color changedBackgroundColor = backgroundColor.brighter();
checkNotColor(changedForegroundColor, cellBounds);
checkNotColor(changedBackgroundColor, cellBounds);
}
});
}
BufferedImage img = new BufferedImage(listWidth, listHeight,
private static void checkColor(Color colorCheck, Rectangle bounds) {
if (!findColor(colorCheck, bounds)) {
String error = "[ERROR][" + colorCheck.toString()
+ "] Not found in selected cell";
errorString += error;
}
}
private static void checkNotColor(Color colorCheck, Rectangle bounds) {
if (findColor(colorCheck, bounds)) {
String error = "[ERROR][" + colorCheck.toString()
+ "] is found in selected cell. "
+ "Not supposed to be found in negative test case";
errorString += error;
}
}
private static boolean findColor(Color colorCheck, Rectangle bounds) {
BufferedImage img = new BufferedImage(bounds.width,
bounds.height,
BufferedImage.TYPE_INT_ARGB);
Graphics g = img.getGraphics();
list.paint(g);
g.dispose();
Rectangle cellRect = list.getCellBounds(selCellIndex, selCellIndex);
HashSet<Color> cellColors = new HashSet<Color>();
int uniqueColorIndex = 0;
for (int x = cellRect.x; x < (cellRect.x + cellRect.width); x++) {
for (int y = cellRect.y; y < (cellRect.y + cellRect.height); y++) {
Color cellColor = new Color(img.getRGB(x, y), true);
if (cellColors.add(cellColor)) {
System.err.println(String.format("Cell color #%d: %s",
uniqueColorIndex++, cellColor));
checkLoops:
for (int x = 0; x < bounds.width; x++) {
for (int y = 0; y < bounds.height; y++) {
Point relativePointCheck = new Point(bounds.x + x, bounds.y + y);
robot.mouseMove(relativePointCheck.x, relativePointCheck.y);
Color detectedColor = robot.getPixelColor(relativePointCheck.x,
relativePointCheck.y);
if (detectedColor.equals(colorCheck)) {
return true;
}
if (isMac()) {
//One more chance for Mac due to non-Generic display setting
detectedColor = new Color(img.getRGB(x, y), true);
if (detectedColor.equals(colorCheck)) {
return true;
}
}
}
}
return false;
}
Color selForegroundColor = list.getSelectionForeground();
Color selBackgroundColor = list.getSelectionBackground();
if (!cellColors.contains(new Color(selForegroundColor.getRGB(), true))) {
throw new RuntimeException(String.format(
"Selected cell is drawn without selection foreground color '%s'.",
selForegroundColor));
}
if (!cellColors.contains(new Color(selBackgroundColor.getRGB(), true))) {
throw new RuntimeException(String.format(
"Selected cell is drawn without selection background color '%s'.",
selBackgroundColor));
private static boolean isMac() {
String osName = System.getProperty("os.name");
return osName.contains("Mac");
}
private static void cleanUp() throws Exception {
SwingUtilities.invokeAndWait(new Runnable() {
@Override
public void run() {
frame.dispose();
}
});
} catch (UnsupportedLookAndFeelException | InterruptedException | InvocationTargetException e) {
throw new RuntimeException(e);
}
}
}