test/jdk/java/awt/print/PageFormat/WrongPaperPrintingTest.java
author erikj
Tue, 12 Sep 2017 19:03:39 +0200
changeset 47216 71c04702a3d5
parent 45520 jdk/test/java/awt/print/PageFormat/WrongPaperPrintingTest.java@78fc4902bcbf
child 48268 baad9dc0eab1
permissions -rw-r--r--
8187443: Forest Consolidation: Move files to unified layout Reviewed-by: darcy, ihse
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    25
   @bug 8167102
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    26
   @summary PrintRequestAttributeSet breaks page size set using PageFormat
45520
78fc4902bcbf 8181192: [macos] javafx.print.PrinterJob.showPrintDialog() hangs on macOS
alitvinov
parents: 44657
diff changeset
    27
   @ignore Exclude the test until 8167102 is resolved by a new reassessed fix
44657
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    28
   @run main/manual WrongPaperPrintingTest
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    31
import java.awt.BorderLayout;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    32
import java.awt.Color;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    33
import java.awt.FlowLayout;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    34
import java.awt.Graphics;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    35
import java.awt.event.WindowAdapter;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    36
import java.awt.event.WindowEvent;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    37
import java.awt.print.PageFormat;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    38
import java.awt.print.Paper;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    39
import java.awt.print.Printable;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    40
import java.awt.print.PrinterException;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    41
import java.awt.print.PrinterJob;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    42
import java.util.concurrent.CountDownLatch;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    43
import java.util.concurrent.TimeUnit;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    44
import javax.print.attribute.HashPrintRequestAttributeSet;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    45
import javax.print.attribute.PrintRequestAttributeSet;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    46
import javax.print.attribute.Size2DSyntax;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    47
import javax.print.attribute.standard.Chromaticity;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    48
import javax.print.attribute.standard.MediaSize;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    49
import javax.print.attribute.standard.MediaSizeName;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    50
import javax.swing.JButton;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    51
import javax.swing.JDialog;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    52
import javax.swing.JLabel;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    53
import javax.swing.JPanel;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    54
import javax.swing.JTextArea;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    55
import javax.swing.SwingUtilities;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    56
import javax.swing.Timer;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    57
import javax.swing.WindowConstants;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    58
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    59
public class WrongPaperPrintingTest implements Printable {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    60
    private static final CountDownLatch testEndedSignal = new CountDownLatch(1);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    61
    private static final int testTimeout = 300000;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    62
    private static volatile String testFailureMsg;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    63
    private static volatile boolean testPassed;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    64
    private static volatile boolean testFinished;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    65
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    66
    public static void main(String[] args) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    67
        SwingUtilities.invokeLater(() -> createAndShowTestDialog());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    68
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    69
        try {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    70
            if (!testEndedSignal.await(testTimeout, TimeUnit.MILLISECONDS)) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    71
                throw new RuntimeException(String.format(
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    72
                    "Test timeout '%d ms' elapsed.", testTimeout));
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    73
            }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    74
            if (!testPassed) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    75
                String failureMsg = testFailureMsg;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    76
                if ((failureMsg != null) && (!failureMsg.trim().isEmpty())) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    77
                    throw new RuntimeException(failureMsg);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    78
                } else {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    79
                    throw new RuntimeException("Test failed.");
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
            }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    82
        } catch (InterruptedException ie) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    83
            throw new RuntimeException(ie);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    84
        } finally {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    85
            testFinished = true;
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    89
    private static void doTest() {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    90
        PrintRequestAttributeSet aset = new HashPrintRequestAttributeSet();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    91
        aset.add(Chromaticity.MONOCHROME);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    92
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    93
        MediaSize isoA5Size = MediaSize.getMediaSizeForName(MediaSizeName.ISO_A5);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    94
        float[] size = isoA5Size.getSize(Size2DSyntax.INCH);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    95
        Paper paper = new Paper();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    96
        paper.setSize(size[0] * 72.0, size[1] * 72.0);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    97
        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
    98
        PageFormat pf = new PageFormat();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
    99
        pf.setPaper(paper);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   100
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   101
        PrinterJob job = PrinterJob.getPrinterJob();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   102
        job.setPrintable(new WrongPaperPrintingTest(), job.validatePage(pf));
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   103
        if (job.printDialog()) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   104
            try {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   105
                job.print(aset);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   106
            } catch (PrinterException pe) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   107
                throw new RuntimeException(pe);
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   112
    private static void pass() {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   113
        testPassed = true;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   114
        testEndedSignal.countDown();
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   117
    private static void fail(String failureMsg) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   118
        testFailureMsg = failureMsg;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   119
        testPassed = false;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   120
        testEndedSignal.countDown();
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   123
    private static String convertMillisToTimeStr(int millis) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   124
        if (millis < 0) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   125
            return "00:00:00";
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   126
        }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   127
        int hours = millis / 3600000;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   128
        int minutes = (millis - hours * 3600000) / 60000;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   129
        int seconds = (millis - hours * 3600000 - minutes * 60000) / 1000;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   130
        return String.format("%02d:%02d:%02d", hours, minutes, seconds);
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   133
    private static void createAndShowTestDialog() {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   134
        String description =
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   135
            " 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
   136
            " 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
   137
            "\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   138
            " 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
   139
            " printer to be used.\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   140
            " 2. Click on \"Start Test\" button.\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   141
            " 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
   142
            " on \"Print\" button.\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   143
            " 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
   144
            " 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
   145
            " (148 x 210 mm).\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   146
            "\r\n" +
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   147
            " 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
   148
            " button, otherwise click on \"FAIL\" button.";
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   149
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   150
        final JDialog dialog = new JDialog();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   151
        dialog.setTitle("WrongPaperPrintingTest");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   152
        dialog.setDefaultCloseOperation(WindowConstants.DISPOSE_ON_CLOSE);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   153
        dialog.addWindowListener(new WindowAdapter() {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   154
            @Override
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   155
            public void windowClosing(WindowEvent e) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   156
                dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   157
                fail("Main dialog was closed.");
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   161
        final JLabel testTimeoutLabel = new JLabel(String.format(
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   162
            "Test timeout: %s", convertMillisToTimeStr(testTimeout)));
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   163
        final long startTime = System.currentTimeMillis();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   164
        final Timer timer = new Timer(0, null);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   165
        timer.setDelay(1000);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   166
        timer.addActionListener((e) -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   167
            int leftTime = testTimeout - (int)(System.currentTimeMillis() - startTime);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   168
            if ((leftTime < 0) || testFinished) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   169
                timer.stop();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   170
                dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   171
            }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   172
            testTimeoutLabel.setText(String.format(
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   173
                "Test timeout: %s", convertMillisToTimeStr(leftTime)));
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   174
        });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   175
        timer.start();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   176
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   177
        JTextArea textArea = new JTextArea(description);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   178
        textArea.setEditable(false);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   179
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   180
        final JButton testButton = new JButton("Start Test");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   181
        final JButton passButton = new JButton("PASS");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   182
        final JButton failButton = new JButton("FAIL");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   183
        testButton.addActionListener((e) -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   184
            testButton.setEnabled(false);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   185
            new Thread(() -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   186
                try {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   187
                    doTest();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   188
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   189
                    SwingUtilities.invokeLater(() -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   190
                        passButton.setEnabled(true);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   191
                        failButton.setEnabled(true);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   192
                    });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   193
                } catch (Throwable t) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   194
                    t.printStackTrace();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   195
                    dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   196
                    fail("Exception occurred in a thread executing the test.");
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   197
                }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   198
            }).start();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   199
        });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   200
        passButton.setEnabled(false);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   201
        passButton.addActionListener((e) -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   202
            dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   203
            pass();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   204
        });
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   205
        failButton.setEnabled(false);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   206
        failButton.addActionListener((e) -> {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   207
            dialog.dispose();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   208
            fail("Size of a printed page is wrong.");
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   211
        JPanel mainPanel = new JPanel(new BorderLayout());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   212
        JPanel labelPanel = new JPanel(new FlowLayout());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   213
        labelPanel.add(testTimeoutLabel);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   214
        mainPanel.add(labelPanel, BorderLayout.NORTH);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   215
        mainPanel.add(textArea, BorderLayout.CENTER);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   216
        JPanel buttonPanel = new JPanel(new FlowLayout());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   217
        buttonPanel.add(testButton);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   218
        buttonPanel.add(passButton);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   219
        buttonPanel.add(failButton);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   220
        mainPanel.add(buttonPanel, BorderLayout.SOUTH);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   221
        dialog.add(mainPanel);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   222
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   223
        dialog.pack();
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   224
        dialog.setVisible(true);
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
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   227
    @Override
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   228
    public int print(Graphics g, PageFormat pf, int pageIndex)
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   229
        throws PrinterException {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   230
        if (pageIndex == 0) {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   231
            g.setColor(Color.RED);
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   232
            g.drawRect((int)pf.getImageableX(), (int)pf.getImageableY(),
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   233
                (int)pf.getImageableWidth(), (int)pf.getImageableHeight());
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   234
            return Printable.PAGE_EXISTS;
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   235
        } else {
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   236
            return Printable.NO_SUCH_PAGE;
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
    }
e926e753a4c7 8167102: [macosx] PrintRequestAttributeSet breaks page size set using PageFormat
alitvinov
parents:
diff changeset
   239
}