Reviewer needed - second revision of renderer regression tests
Dr Andrew John Hughes
ahughes at redhat.com
Thu Dec 16 15:04:42 PST 2010
On 17:47 Thu 16 Dec , Denis Lila wrote:
> Hello again.
>
> Attached is the hg diff for the patch in my previous e-mail.
>
> ChangeLog:
> @@ -1,3 +1,8 @@
> +2010-12-16 Denis Lila <dlila at redhar.com>, Pavel Tisnovsky <ptisnovs at redhat.com>
> +
> + * patches/rendering-engine-tests.patch:
> + Improved the tests by using the rendering engine explicitly.
> +
>
> Should I push?
>
Please put Pavel's name on a new line underneath yours.
I'll leave Pavel to comment on the content of the patch.
> Thank you,
> Denis.
>
> ----- "Denis Lila" <dlila at redhat.com> wrote:
>
> > Hi all.
> >
> > This is a slightly modified version of what Pavel sent out.
> > It's exactly the same except it adds the tests in the proper
> > directory and it doesn't have tabs and trailing whitespace.
> >
> > Ok to push?
> >
> > Regards,
> > Denis.
> diff -r 2a1bf7104cc8 ChangeLog
> --- a/ChangeLog Thu Dec 16 18:34:51 2010 +0100
> +++ b/ChangeLog Thu Dec 16 17:47:36 2010 -0500
> @@ -1,3 +1,8 @@
> +2010-12-16 Denis Lila <dlila at redhar.com>, Pavel Tisnovsky <ptisnovs at redhat.com>
> +
> + * patches/rendering-engine-tests.patch:
> + Improved the tests by using the rendering engine explicitly.
> +
> 2010-12-16 Pavel Tisnovsky <ptisnovs at redhat.com>
>
> * Makefile.am: Add new patch.
> diff -r 2a1bf7104cc8 patches/rendering-engine-tests.patch
> --- a/patches/rendering-engine-tests.patch Thu Dec 16 18:34:51 2010 +0100
> +++ b/patches/rendering-engine-tests.patch Thu Dec 16 17:47:36 2010 -0500
> @@ -1,7 +1,7 @@
> -diff -Nu openjdk-old/jdk/test/java/awt/Graphics2D/RenderingEngineTests/RenderingEngineTest.java openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/RenderingEngineTest.java
> ---- /dev/null
> -+++ openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/RenderingEngineTest.java 2010-12-13 16:55:44.000000000 +0100
> -@@ -0,0 +1,39 @@
> +diff -Nr --unified=5 ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/RenderingEngineTest.java ./openjdk/jdk/test/sun/java2d/pisces/Renderer/RenderingEngineTest.java
> +--- ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/RenderingEngineTest.java 1969-12-31 19:00:00.000000000 -0500
> ++++ ./openjdk/jdk/test/sun/java2d/pisces/Renderer/RenderingEngineTest.java 2010-12-15 15:57:11.881597163 -0500
> +@@ -0,0 +1,89 @@
> +/*
> + * Copyright 2010 Red Hat, Inc. All Rights Reserved.
> + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
> @@ -22,14 +22,21 @@
> + */
> +
> +import java.awt.Color;
> -+import java.awt.Graphics;
> +import java.awt.Graphics2D;
> ++import java.awt.Shape;
> ++import java.awt.geom.Path2D;
> +import java.awt.image.BufferedImage;
> ++import sun.awt.geom.PathConsumer2D;
> +
> +/*
> + * Helper class for rendering engine tests.
> + */
> -+public class RenderingEngineTest {
> ++public abstract class RenderingEngineTest implements Runnable {
> ++
> ++ public abstract void run();
> ++
> ++ protected static sun.java2d.pipe.RenderingEngine re =
> ++ sun.java2d.pipe.RenderingEngine.getInstance();
> +
> + protected static Object[] getGraphics(int w, int h) {
> + BufferedImage bi = new BufferedImage(w, h, BufferedImage.TYPE_INT_RGB);
> @@ -39,11 +46,102 @@
> + g2.setColor(Color.black);
> + return new Object[] {bi, g2};
> + }
> ++
> ++ protected static class ShapeCreatorPC2D implements PathConsumer2D {
> ++
> ++ Path2D p2d = new Path2D.Double();
> ++
> ++ @Override
> ++ public void closePath() {
> ++ p2d.closePath();
> ++ }
> ++
> ++ @Override
> ++ public void curveTo(float x1, float y1, float x2, float y2, float x3, float y3) {
> ++ p2d.curveTo(x1, y1, x2, y2, x3, y3);
> ++ }
> ++
> ++ @Override
> ++ public long getNativeConsumer() {
> ++ return 0;
> ++ }
> ++
> ++ @Override
> ++ public void lineTo(float x, float y) {
> ++ p2d.lineTo(x, y);
> ++ }
> ++
> ++ @Override
> ++ public void moveTo(float x, float y) {
> ++ p2d.moveTo(x, y);
> ++ }
> ++
> ++ @Override
> ++ public void pathDone() {
> ++ }
> ++
> ++ @Override
> ++ public void quadTo(float x1, float y1, float x2, float y2) {
> ++ p2d.quadTo(x1, y1, x2, y2);
> ++ }
> ++
> ++ public Shape getShape() {
> ++ return p2d;
> ++ }
> ++ }
> +}
> +
> -diff -Nu openjdk-old/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test661554.java openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test661554.java
> ---- /dev/null
> -+++ openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test661554.java 2010-12-13 16:56:26.000000000 +0100
> +diff -Nr --unified=5 ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test661554.java ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test661554.java
> +--- ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test661554.java 1969-12-31 19:00:00.000000000 -0500
> ++++ ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test661554.java 2010-12-15 15:57:11.881597163 -0500
> +@@ -0,0 +1,44 @@
> ++/*
> ++ * Copyright 2010 Red Hat, Inc. 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.
> ++ */
> ++
> ++import java.awt.BasicStroke;
> ++import java.awt.geom.AffineTransform;
> ++import java.awt.geom.Line2D;
> ++
> ++/*
> ++ * @test
> ++ * bug 661554 - note that this is a Red Hat bugzilla bug ID, so we cannot
> ++ * use real tag "bug" (starting with "at" character) here.
> ++ * @summary This test check rendering of dashed lines with applied scaling.
> ++ * @run main Test661554
> ++ * @author Denis Lila <dlila at redhat.com>, Pavel Tisnovsky <ptisnovs at redhat.com>
> ++ */
> ++public class Test661554 extends RenderingEngineTest {
> ++ public void run() {
> ++ AffineTransform at = new AffineTransform();
> ++ at.scale(0.0000001, 0.0000001);
> ++ ShapeCreatorPC2D pc2d = new ShapeCreatorPC2D();
> ++ re.strokeTo(new Line2D.Double(10, 10, 10, 100), at, new BasicStroke(2f), false, false, false, pc2d);
> ++ }
> ++
> ++ public static void main(String[] argv) {
> ++ new Test661554().run();
> ++ }
> ++}
> ++
> +diff -Nr --unified=5 ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test6967433.java ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test6967433.java
> +--- ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test6967433.java 1969-12-31 19:00:00.000000000 -0500
> ++++ ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test6967433.java 2010-12-15 15:57:11.882597017 -0500
> @@ -0,0 +1,55 @@
> +/*
> + * Copyright 2010 Red Hat, Inc. All Rights Reserved.
> @@ -64,46 +162,46 @@
> + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
> + */
> +
> -+import java.awt.*;
> -+import static java.awt.RenderingHints.*;
> -+import java.awt.image.*;
> ++import java.awt.BasicStroke;
> ++import java.awt.geom.AffineTransform;
> ++import java.awt.geom.Line2D;
> +
> +/*
> + * @test
> -+ * bug 661554 - note that this is a Red Hat bugzilla bug ID, so we cannot
> -+ * use real tag "bug" (starting with "at" character) here.
> ++ * @bug 6967433
> + * @summary This test check rendering of dashed lines with applied scaling.
> -+ * @run main Test661554
> ++ * @run main Test6967433
> + * @author Denis Lila <dlila at redhat.com>, Pavel Tisnovsky <ptisnovs at redhat.com>
> + */
> -+public class Test661554 extends RenderingEngineTest {
> ++
> ++public class Test6967433 extends RenderingEngineTest {
> ++
> + public void run() {
> -+ Graphics2D g2 = (Graphics2D) getGraphics(400, 400)[1];
> ++ // draw dashed line using scaling (magnification)
> ++ ShapeCreatorPC2D pc2d = new ShapeCreatorPC2D();
> ++ final int scale = 32;
> ++ AffineTransform at = new AffineTransform();
> ++ at.scale(scale, scale);
> ++ re.strokeTo(new Line2D.Double(0, 0, 10, 0),
> ++ at,
> ++ new BasicStroke(1f, BasicStroke.CAP_BUTT, BasicStroke.JOIN_BEVEL, 1, new float[] {1,1}, 0),
> ++ false, false, false,
> ++ pc2d);
> +
> -+ g2.setRenderingHint(KEY_ANTIALIASING, VALUE_ANTIALIAS_ON);
> -+ g2.setStroke(new BasicStroke(2f));
> -+ g2.scale(0.0000001, 0.0000001);
> -+
> -+ // draw line using minification and check if divide by zero is not thrown
> -+ try {
> -+ g2.drawLine(10, 10, 10, 100);
> -+ }
> -+ catch (ArithmeticException e) {
> -+ // this might be kinda stupid. Maybe we should just let the DVZ
> -+ // fall through.
> -+ throw new RuntimeException("Divide by zero occurred; test failed.");
> ++ if (pc2d.getShape().contains(scale + scale/2, 0)) {
> ++ throw new RuntimeException("ScaledDashedLines test failed.");
> + }
> + }
> +
> -+ public static void main(String[] argv) {
> -+ new Test661554().run();
> ++ public static void main(String[] args) {
> ++ new Test6967433().run();
> + }
> +}
> +
> -diff -Nu openjdk-old/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6967433.java openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6967433.java
> ---- /dev/null
> -+++ openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6967433.java 2010-12-13 16:57:42.000000000 +0100
> -@@ -0,0 +1,59 @@
> +diff -Nr --unified=5 ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test6967434.java ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test6967434.java
> +--- ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test6967434.java 1969-12-31 19:00:00.000000000 -0500
> ++++ ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test6967434.java 2010-12-15 15:57:11.881597163 -0500
> +@@ -0,0 +1,63 @@
> +/*
> + * Copyright 2010 Red Hat, Inc. All Rights Reserved.
> + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
> @@ -123,50 +221,54 @@
> + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
> + */
> +
> -+import java.awt.*;
> -+import java.awt.image.*;
> -+import static java.awt.RenderingHints.*;
> ++import java.awt.BasicStroke;
> ++import java.awt.Shape;
> ++import java.awt.geom.AffineTransform;
> ++import java.awt.geom.Line2D;
> +
> +/*
> + * @test
> -+ * @bug 6967433
> -+ * @summary This test check rendering of dashed lines with applied scaling.
> -+ * @run main Test6967433
> ++ * @bug 6967434
> ++ * @summary This test check rendering of scaled up lines.
> ++ * @run main Test6967434
> + * @author Denis Lila <dlila at redhat.com>, Pavel Tisnovsky <ptisnovs at redhat.com>
> + */
> +
> -+// TODO: this test uses lines. That's good for now, but it should really use
> -+// Path2Ds as Shapes. That's because lines could be treated as special cases,
> -+// and the code we want to test (in the rendering engine) might not even run.
> -+// So we must use shapes that are as general as possible.
> -+public class Test6967433 extends RenderingEngineTest {
> ++public class Test6967434 extends RenderingEngineTest {
> +
> + public void run() {
> -+ Object[] tmp = getGraphics(400, 400);
> -+ BufferedImage bi = (BufferedImage) tmp[0];
> -+ Graphics2D g2 = (Graphics2D) tmp[1];
> ++ final float scale = 100;
> ++ final float width = 1;
> ++ final int sw = (int)(scale*width/2);
> +
> -+ // draw dashed line using scaling (magnification)
> -+ final int scale = 32;
> -+ g2.setStroke(new BasicStroke(1f, BasicStroke.CAP_BUTT, BasicStroke.JOIN_BEVEL, 1, new float[] {1,1}, 0));
> -+ g2.scale(scale, scale);
> -+ g2.drawLine(0, 0, 10, 0);
> ++ AffineTransform at = new AffineTransform();
> ++ at.translate(sw, sw);
> ++ at.scale(scale, scale);
> +
> -+ // test if dashed shape rendering is correct
> -+ if (new Color(bi.getRGB(scale + scale/2, 0)).equals(Color.black)) {
> -+ throw new RuntimeException("ScaledDashedLines test failed.");
> ++ BasicStroke bs = new BasicStroke(width, BasicStroke.CAP_ROUND, BasicStroke.JOIN_BEVEL);
> ++
> ++ ShapeCreatorPC2D pc2d = new ShapeCreatorPC2D();
> ++
> ++ re.strokeTo(new Line2D.Double(0, 0, 1, 0), at, bs, false, false, false, pc2d);
> ++ Shape result = pc2d.getShape();
> ++
> ++ final int middle = sw/2;
> ++ // test if shape rendering is correct
> ++ if (!(result.contains(middle - 2, middle - 2) &&
> ++ result.contains(middle - 2, sw + middle + 2))) {
> ++ throw new RuntimeException("ScaledRoundCapsTest test failed.");
> + }
> + }
> +
> -+ public static void main(String[] args) {
> -+ new Test6967433().run();
> -+ }
> ++ public static void main(String[] argv) {
> ++ new Test6967434().run();
> ++ }
> +}
> +
> -diff -Nu openjdk-old/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6967434.java openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6967434.java
> ---- /dev/null
> -+++ openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6967434.java 2010-12-13 16:57:53.000000000 +0100
> -@@ -0,0 +1,64 @@
> +diff -Nr --unified=5 ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test6967436.java ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test6967436.java
> +--- ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test6967436.java 1969-12-31 19:00:00.000000000 -0500
> ++++ ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test6967436.java 2010-12-15 15:57:11.882597017 -0500
> +@@ -0,0 +1,51 @@
> +/*
> + * Copyright 2010 Red Hat, Inc. All Rights Reserved.
> + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
> @@ -186,55 +288,42 @@
> + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
> + */
> +
> -+import java.awt.*;
> -+import java.awt.image.*;
> -+import static java.awt.RenderingHints.*;
> ++import java.awt.BasicStroke;
> ++import java.awt.geom.Line2D;
> ++import java.awt.geom.Rectangle2D;
> +
> +/*
> + * @test
> -+ * @bug 6967434
> -+ * @summary This test check rendering of scaled up lines.
> -+ * @run main Test6967434
> ++ * @bug 6967436
> ++ * @summary This test check proper rendering of diagonal line when line coordinates are bigger than 16bit integer.
> ++ * @run main Test6967436
> + * @author Denis Lila <dlila at redhat.com>, Pavel Tisnovsky <ptisnovs at redhat.com>
> + */
> +
> -+// TODO: this test uses lines. That's good for now, but it should really use
> -+// Path2Ds as Shapes. That's because lines could be treated as special cases,
> -+// and the code we want to test (in the rendering engine) might not even run.
> -+// So we must use shapes that are as general as possible.
> -+public class Test6967434 extends RenderingEngineTest {
> ++public class Test6967436 extends RenderingEngineTest {
> +
> + public void run() {
> -+ Object[] tmp = getGraphics(400, 400);
> -+ BufferedImage bi = (BufferedImage) tmp[0];
> -+ Graphics2D g2 = (Graphics2D) tmp[1];
> ++ ShapeCreatorPC2D pc2d = new ShapeCreatorPC2D();
> ++ re.strokeTo(new Line2D.Double(0, 0, 1, 1 << 16), null, new BasicStroke(), false, false, false, pc2d);
> ++ Rectangle2D bounds = pc2d.getShape().getBounds2D();
> ++ double minx = bounds.getMinX();
> ++ double maxx = bounds.getMaxX();
> ++ double miny = bounds.getMinY();
> +
> -+ // draw line using custom transformation
> -+ final float scale = 100;
> -+ final float width = 1;
> -+ g2.setStroke(new BasicStroke(width, BasicStroke.CAP_ROUND, BasicStroke.JOIN_BEVEL));
> -+ final int sw = (int)(scale*width/2);
> -+ g2.translate(sw, sw);
> -+ g2.scale(scale, scale);
> -+ g2.drawLine(0, 0, 1, 0);
> -+ final int middle = sw/2;
> -+
> -+ // test if shape rendering is correct
> -+ if (!(new Color(bi.getRGB(middle-2, middle - 2)).equals(Color.black) &&
> -+ new Color(bi.getRGB(middle-2, sw + middle + 2)).equals(Color.black))) {
> -+ throw new RuntimeException("ScaledRoundCapsTest test failed.");
> ++ if (miny < -1 || minx < -1 || maxx > 2) {
> ++ throw new RuntimeException(" There was an overflow in the rendering engine.");
> + }
> + }
> +
> + public static void main(String[] argv) {
> -+ new Test6967434().run();
> ++ new Test6967436().run();
> + }
> +}
> +
> -diff -Nu openjdk-old/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6967436.java openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6967436.java
> ---- /dev/null
> -+++ openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6967436.java 2010-12-13 16:58:34.000000000 +0100
> -@@ -0,0 +1,69 @@
> +diff -Nr --unified=5 ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test6976265.java ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test6976265.java
> +--- ./openjdk.old/jdk/test/sun/java2d/pisces/Renderer/Test6976265.java 1969-12-31 19:00:00.000000000 -0500
> ++++ ./openjdk/jdk/test/sun/java2d/pisces/Renderer/Test6976265.java 2010-12-15 15:57:11.881597163 -0500
> +@@ -0,0 +1,49 @@
> +/*
> + * Copyright 2010 Red Hat, Inc. All Rights Reserved.
> + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
> @@ -254,82 +343,9 @@
> + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
> + */
> +
> -+import java.awt.*;
> -+import java.awt.image.*;
> -+import static java.awt.RenderingHints.*;
> -+
> -+/*
> -+ * @test
> -+ * @bug 6967436
> -+ * @summary This test check proper rendering of diagonal line when line coordinates are bigger than 16bit integer.
> -+ * @run main Test6967436
> -+ * @author Denis Lila <dlila at redhat.com>, Pavel Tisnovsky <ptisnovs at redhat.com>
> -+ */
> -+
> -+// TODO: this test use lines. That's good for now, but it should really use
> -+// Path2Ds as Shapes. That's because lines could be treated as special cases,
> -+// and the code we want to test (in the rendering engine) might not even run.
> -+// So we must use shapes that are as general as possible.
> -+public class Test6967436 extends RenderingEngineTest {
> -+
> -+ public void run() {
> -+ // NOTE - the rendering area should be square, not generic rectangle
> -+ Object[] tmp = getGraphics(400, 400);
> -+ BufferedImage bi = (BufferedImage) tmp[0];
> -+ Graphics2D g2 = (Graphics2D) tmp[1];
> -+
> -+ g2.setStroke(new BasicStroke(5));
> -+ g2.setRenderingHint(KEY_ANTIALIASING, VALUE_ANTIALIAS_ON);
> -+
> -+ g2.drawLine(0, 0, 1<<15, 1<<15);
> -+
> -+ // test if two areas (above line and below line) contains only
> -+ // white pixels
> -+ int w = bi.getWidth(), h = bi.getHeight();
> -+ for (int i = 0; i < h; i++) {
> -+ for (int j = i + 10; j < w; j++) {
> -+ if (!(new Color(bi.getRGB(j, i)).equals(Color.white) &&
> -+ new Color(bi.getRGB(i, j)).equals(Color.white)))
> -+ {
> -+ throw new RuntimeException(
> -+ "A non white background pixel was found.\n" +
> -+ "OverflowTest failed");
> -+ }
> -+ }
> -+ }
> -+ }
> -+
> -+ public static void main(String[] argv) {
> -+ new Test6967436().run();
> -+ }
> -+}
> -+
> -diff -Nu openjdk-old/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6976265.java openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6976265.java
> ---- /dev/null
> -+++ openjdk/jdk/test/java/awt/Graphics2D/RenderingEngineTests/Test6976265.java 2010-12-13 16:32:29.000000000 +0100
> -@@ -0,0 +1,57 @@
> -+/*
> -+ * Copyright 2010 Red Hat, Inc. 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.
> -+ */
> -+
> -+import java.awt.*;
> -+import java.awt.image.*;
> -+import static java.awt.RenderingHints.*;
> ++import java.awt.BasicStroke;
> ++import java.awt.geom.Line2D;
> ++import java.awt.geom.Rectangle2D;
> +
> +/*
> + * @test
> @@ -339,24 +355,16 @@
> + * @author Denis Lila <dlila at redhat.com>, Pavel Tisnovsky <ptisnovs at redhat.com>
> + */
> +
> -+// TODO: this test uses lines. That's good for now, but it should really use
> -+// Path2Ds as Shapes. That's because lines could be treated as special cases,
> -+// and the code we want to test (in the rendering engine) might not even run.
> -+// So we must use shapes that are as general as possible.
> +public class Test6976265 extends RenderingEngineTest {
> +
> + public void run() {
> -+ Object[] tmp = getGraphics(400, 400);
> -+ BufferedImage bi = (BufferedImage) tmp[0];
> -+ Graphics2D g2 = (Graphics2D) tmp[1];
> -+
> -+ g2.setRenderingHint(KEY_STROKE_CONTROL, VALUE_STROKE_NORMALIZE);
> -+ g2.setRenderingHint(KEY_ANTIALIASING, VALUE_ANTIALIAS_ON);
> -+ g2.drawLine(10, 10, 10, 100);
> -+
> -+ // test if rendering is correct
> -+ if (! new Color(bi.getRGB(10, 10)).equals(Color.black)) {
> -+ throw new RuntimeException("StrokeControlTest test failed.");
> ++ ShapeCreatorPC2D pc2d = new ShapeCreatorPC2D();
> ++ re.strokeTo(new Line2D.Double(10, 10, 10, 100), null, new BasicStroke(), false, true, true, pc2d);
> ++ Rectangle2D bounds = pc2d.getShape().getBounds2D();
> ++ for (int i = 10; i < 100; i++) {
> ++ if (bounds.contains(9.75, i) || !bounds.contains(10.75, i)) {
> ++ throw new RuntimeException("StrokeControlTest test failed.");
> ++ }
> + }
> + }
> +
--
Andrew :)
Free Java Software Engineer
Red Hat, Inc. (http://www.redhat.com)
Support Free Java!
Contribute to GNU Classpath and IcedTea
http://www.gnu.org/software/classpath
http://icedtea.classpath.org
PGP Key: 94EFD9D8 (http://subkeys.pgp.net)
Fingerprint = F8EF F1EA 401E 2E60 15FA 7927 142C 2591 94EF D9D8
More information about the distro-pkg-dev
mailing list