test/jdk/java/awt/print/PageFormat/WrongPaperPrintingTest.java
author alitvinov
Sun, 03 Dec 2017 13:21:41 +0000
changeset 48268 baad9dc0eab1
parent 47216 71c04702a3d5
permissions -rw-r--r--
8181659: Create an alternative fix for JDK-8167102, whose fix was backed out Reviewed-by: prr, serb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
44657
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
     1
/*
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
     2
 * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
     4
 *
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
     7
 * published by the Free Software Foundation.
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
     8
 *
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    13
 * accompanied this code).
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    14
 *
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    18
 *
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    21
 * questions.
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    22
 */
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    23
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    24
/* @test
48268
baad9dc0eab1 8181659: Create an alternative fix for JDK-8167102, whose fix was backed out
alitvinov
parents: 47216
diff changeset
    25
   @bug 8167102 8181659
44657
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    26
   @summary PrintRequestAttributeSet breaks page size set using PageFormat
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    27
   @run main/manual WrongPaperPrintingTest
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    28
 */
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    29
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    30
import java.awt.BorderLayout;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    31
import java.awt.Color;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    32
import java.awt.FlowLayout;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    33
import java.awt.Graphics;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    34
import java.awt.event.WindowAdapter;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    35
import java.awt.event.WindowEvent;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    36
import java.awt.print.PageFormat;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    37
import java.awt.print.Paper;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    38
import java.awt.print.Printable;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    39
import java.awt.print.PrinterException;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    40
import java.awt.print.PrinterJob;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    41
import java.util.concurrent.CountDownLatch;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    42
import java.util.concurrent.TimeUnit;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    43
import javax.print.attribute.HashPrintRequestAttributeSet;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    44
import javax.print.attribute.PrintRequestAttributeSet;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    45
import javax.print.attribute.Size2DSyntax;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    46
import javax.print.attribute.standard.Chromaticity;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    47
import javax.print.attribute.standard.MediaSize;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    48
import javax.print.attribute.standard.MediaSizeName;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    49
import javax.swing.JButton;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    50
import javax.swing.JDialog;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    51
import javax.swing.JLabel;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    52
import javax.swing.JPanel;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    53
import javax.swing.JTextArea;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    54
import javax.swing.SwingUtilities;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    55
import javax.swing.Timer;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    56
import javax.swing.WindowConstants;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    57
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    58
public class WrongPaperPrintingTest implements Printable {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    59
    private static final CountDownLatch testEndedSignal = new CountDownLatch(1);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    60
    private static final int testTimeout = 300000;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    61
    private static volatile String testFailureMsg;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    62
    private static volatile boolean testPassed;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    63
    private static volatile boolean testFinished;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    64
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    65
    public static void main(String[] args) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    66
        SwingUtilities.invokeLater(() -> createAndShowTestDialog());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    67
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    68
        try {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    69
            if (!testEndedSignal.await(testTimeout, TimeUnit.MILLISECONDS)) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    70
                throw new RuntimeException(String.format(
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    71
                    "Test timeout '%d ms' elapsed.", testTimeout));
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    72
            }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    73
            if (!testPassed) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    74
                String failureMsg = testFailureMsg;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    75
                if ((failureMsg != null) && (!failureMsg.trim().isEmpty())) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    76
                    throw new RuntimeException(failureMsg);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    77
                } else {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    78
                    throw new RuntimeException("Test failed.");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    79
                }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    80
            }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    81
        } catch (InterruptedException ie) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    82
            throw new RuntimeException(ie);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    83
        } finally {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    84
            testFinished = true;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    85
        }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    86
    }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    87
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    88
    private static void doTest() {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    89
        PrintRequestAttributeSet aset = new HashPrintRequestAttributeSet();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    90
        aset.add(Chromaticity.MONOCHROME);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    91
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    92
        MediaSize isoA5Size = MediaSize.getMediaSizeForName(MediaSizeName.ISO_A5);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    93
        float[] size = isoA5Size.getSize(Size2DSyntax.INCH);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    94
        Paper paper = new Paper();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    95
        paper.setSize(size[0] * 72.0, size[1] * 72.0);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    96
        paper.setImageableArea(0.0, 0.0, size[0] * 72.0, size[1] * 72.0);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    97
        PageFormat pf = new PageFormat();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    98
        pf.setPaper(paper);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    99
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   100
        PrinterJob job = PrinterJob.getPrinterJob();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   101
        job.setPrintable(new WrongPaperPrintingTest(), job.validatePage(pf));
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   102
        if (job.printDialog()) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   103
            try {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   104
                job.print(aset);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   105
            } catch (PrinterException pe) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   106
                throw new RuntimeException(pe);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   107
            }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   108
        }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   109
    }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   110
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   111
    private static void pass() {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   112
        testPassed = true;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   113
        testEndedSignal.countDown();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   114
    }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   115
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   116
    private static void fail(String failureMsg) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   117
        testFailureMsg = failureMsg;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   118
        testPassed = false;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   119
        testEndedSignal.countDown();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   120
    }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   121
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   122
    private static String convertMillisToTimeStr(int millis) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   123
        if (millis < 0) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   124
            return "00:00:00";
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   125
        }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   126
        int hours = millis / 3600000;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   127
        int minutes = (millis - hours * 3600000) / 60000;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   128
        int seconds = (millis - hours * 3600000 - minutes * 60000) / 1000;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   129
        return String.format("%02d:%02d:%02d", hours, minutes, seconds);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   130
    }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   131
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   132
    private static void createAndShowTestDialog() {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   133
        String description =
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   134
            " To run this test it is required to have a virtual PDF\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   135
            " printer or any other printer supporting A5 paper size.\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   136
            "\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   137
            " 1. Verify that NOT A5 paper size is set as default for the\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   138
            " printer to be used.\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   139
            " 2. Click on \"Start Test\" button.\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   140
            " 3. In the shown print dialog select the printer and click\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   141
            " on \"Print\" button.\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   142
            " 4. Verify that a page with a drawn rectangle is printed on\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   143
            " a paper of A5 size which is (5.8 x 8.3 in) or\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   144
            " (148 x 210 mm).\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   145
            "\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   146
            " If the printed page size is correct, click on \"PASS\"\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   147
            " button, otherwise click on \"FAIL\" button.";
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   148
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   149
        final JDialog dialog = new JDialog();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   150
        dialog.setTitle("WrongPaperPrintingTest");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   151
        dialog.setDefaultCloseOperation(WindowConstants.DISPOSE_ON_CLOSE);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   152
        dialog.addWindowListener(new WindowAdapter() {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   153
            @Override
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   154
            public void windowClosing(WindowEvent e) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   155
                dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   156
                fail("Main dialog was closed.");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   157
            }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   158
        });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   159
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   160
        final JLabel testTimeoutLabel = new JLabel(String.format(
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   161
            "Test timeout: %s", convertMillisToTimeStr(testTimeout)));
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   162
        final long startTime = System.currentTimeMillis();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   163
        final Timer timer = new Timer(0, null);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   164
        timer.setDelay(1000);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   165
        timer.addActionListener((e) -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   166
            int leftTime = testTimeout - (int)(System.currentTimeMillis() - startTime);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   167
            if ((leftTime < 0) || testFinished) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   168
                timer.stop();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   169
                dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   170
            }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   171
            testTimeoutLabel.setText(String.format(
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   172
                "Test timeout: %s", convertMillisToTimeStr(leftTime)));
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   173
        });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   174
        timer.start();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   175
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   176
        JTextArea textArea = new JTextArea(description);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   177
        textArea.setEditable(false);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   178
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   179
        final JButton testButton = new JButton("Start Test");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   180
        final JButton passButton = new JButton("PASS");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   181
        final JButton failButton = new JButton("FAIL");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   182
        testButton.addActionListener((e) -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   183
            testButton.setEnabled(false);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   184
            new Thread(() -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   185
                try {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   186
                    doTest();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   187
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   188
                    SwingUtilities.invokeLater(() -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   189
                        passButton.setEnabled(true);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   190
                        failButton.setEnabled(true);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   191
                    });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   192
                } catch (Throwable t) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   193
                    t.printStackTrace();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   194
                    dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   195
                    fail("Exception occurred in a thread executing the test.");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   196
                }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   197
            }).start();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   198
        });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   199
        passButton.setEnabled(false);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   200
        passButton.addActionListener((e) -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   201
            dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   202
            pass();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   203
        });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   204
        failButton.setEnabled(false);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   205
        failButton.addActionListener((e) -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   206
            dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   207
            fail("Size of a printed page is wrong.");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   208
        });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   209
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   210
        JPanel mainPanel = new JPanel(new BorderLayout());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   211
        JPanel labelPanel = new JPanel(new FlowLayout());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   212
        labelPanel.add(testTimeoutLabel);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   213
        mainPanel.add(labelPanel, BorderLayout.NORTH);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   214
        mainPanel.add(textArea, BorderLayout.CENTER);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   215
        JPanel buttonPanel = new JPanel(new FlowLayout());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   216
        buttonPanel.add(testButton);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   217
        buttonPanel.add(passButton);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   218
        buttonPanel.add(failButton);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   219
        mainPanel.add(buttonPanel, BorderLayout.SOUTH);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   220
        dialog.add(mainPanel);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   221
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   222
        dialog.pack();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   223
        dialog.setVisible(true);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   224
    }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   225
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   226
    @Override
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   227
    public int print(Graphics g, PageFormat pf, int pageIndex)
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   228
        throws PrinterException {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   229
        if (pageIndex == 0) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   230
            g.setColor(Color.RED);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   231
            g.drawRect((int)pf.getImageableX(), (int)pf.getImageableY(),
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   232
                (int)pf.getImageableWidth(), (int)pf.getImageableHeight());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   233
            return Printable.PAGE_EXISTS;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   234
        } else {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   235
            return Printable.NO_SUCH_PAGE;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   236
        }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   237
    }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   238
}