From b01f33a7b05043a5e48105b3e632261f9f9c9469 Mon Sep 17 00:00:00 2001 From: Alexander Stepanov Date: Thu, 10 Mar 2016 13:07:41 +0300 Subject: [PATCH] 8151269: [TEST] add test covering getSource() method for multiresolution image Reviewed-by: alexsch, serb --- .../MultiresolutionSourceTest.java | 169 ++++++++++++++++++ 1 file changed, 169 insertions(+) create mode 100644 jdk/test/java/awt/image/multiresolution/MultiresolutionSourceTest.java diff --git a/jdk/test/java/awt/image/multiresolution/MultiresolutionSourceTest.java b/jdk/test/java/awt/image/multiresolution/MultiresolutionSourceTest.java new file mode 100644 index 00000000000..e9aebf4052f --- /dev/null +++ b/jdk/test/java/awt/image/multiresolution/MultiresolutionSourceTest.java @@ -0,0 +1,169 @@ +/* + * Copyright (c) 2016, 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 8151269 + * @author a.stepanov + * @summary Multiresolution image: check that the base resolution variant + * source is passed to the corresponding ImageConsumer + * @run main MultiresolutionSourceTest + */ + +import java.awt.*; +import java.awt.image.*; + +public class MultiresolutionSourceTest { + + private static class Checker implements ImageConsumer { + + private final int refW, refH, refType; + private final boolean refHasAlpha; + private final Color refColor; + + public Checker(int w, + int h, + Color c, + boolean hasAlpha, + int transferType) { + refW = w; + refH = h; + refColor = c; + refHasAlpha = hasAlpha; + refType = transferType; + } + + @Override + public void imageComplete(int status) {} + + @Override + public void setColorModel(ColorModel model) { + + boolean a = model.hasAlpha(); + if (a != refHasAlpha) { + throw new RuntimeException("invalid hasAlpha: " + a); + } + + int tt = model.getTransferType(); + if (tt != refType) { + throw new RuntimeException("invalid transfer type: " + tt); + } + } + + @Override + public void setDimensions(int w, int h) { + + if (w != refW) { throw new RuntimeException("invalid width: " + w + + ", expected: " + refW); } + + if (h != refH) { throw new RuntimeException("invalid height: " + h + + ", expected: " + refH); } + } + + @Override + public void setHints(int flags) {} + + @Override + public void setPixels(int x, int y, int w, int h, ColorModel model, + byte pixels[], int offset, int scansize) { + + for (int i = 0; i < pixels.length; i++) { + int p = pixels[i]; + // just in case... + Color c = model.hasAlpha() ? + new Color(model.getRed (p), + model.getGreen(p), + model.getBlue (p), + model.getAlpha(p)) : + new Color(model.getRGB(p)); + + if (!c.equals(refColor)) { + throw new RuntimeException("invalid color: " + c + + ", expected: " + refColor); + } + } + } + + @Override + public void setPixels(int x, int y, int w, int h, ColorModel model, + int pixels[], int offset, int scansize) { + + for (int i = 0; i < pixels.length; i++) { + int p = pixels[i]; + Color c = model.hasAlpha() ? + new Color(model.getRed (p), + model.getGreen(p), + model.getBlue (p), + model.getAlpha(p)) : + new Color(model.getRGB(p)); + + if (!c.equals(refColor)) { + throw new RuntimeException("invalid color: " + c + + ", expected: " + refColor); + } + } + } + + @Override + public void setProperties(java.util.Hashtable props) {} + } + + private static BufferedImage generateImage(int w, int h, Color c, int type) { + + BufferedImage img = new BufferedImage(w, h, type); + Graphics g = img.getGraphics(); + g.setColor(c); + g.fillRect(0, 0, w, h); + return img; + } + + public static void main(String[] args) { + + final int w1 = 20, w2 = 100, h1 = 30, h2 = 50; + final Color + c1 = new Color(255, 0, 0, 100), c2 = Color.BLACK, gray = Color.GRAY; + + BufferedImage img1 = + generateImage(w1, h1, c1, BufferedImage.TYPE_INT_ARGB); + + BufferedImage dummy = + generateImage(w1 + 5, h1 + 5, gray, BufferedImage.TYPE_BYTE_GRAY); + + BufferedImage img2 = + generateImage(w2, h2, c2, BufferedImage.TYPE_BYTE_BINARY); + + BufferedImage vars[] = new BufferedImage[] {img1, dummy, img2}; + + // default base image index (zero) + BaseMultiResolutionImage mri1 = new BaseMultiResolutionImage(vars); + // base image index = 2 + BaseMultiResolutionImage mri2 = new BaseMultiResolutionImage(2, vars); + + // do checks + mri1.getSource().startProduction( + new Checker(w1, h1, c1, true, DataBuffer.TYPE_INT)); + + mri2.getSource().startProduction( + new Checker(w2, h2, c2, false, DataBuffer.TYPE_BYTE)); + } +}