Skip to content

Commit

Permalink
8320675: PrinterJob/SecurityDialogTest.java hangs
Browse files Browse the repository at this point in the history
Co-authored-by: Alexey Ivanov <aivanov@openjdk.org>
Reviewed-by: aivanov, tr
  • Loading branch information
2 people authored and Tejesh R committed Mar 21, 2024
1 parent 684678f commit 9f5ad43
Showing 1 changed file with 84 additions and 184 deletions.
268 changes: 84 additions & 184 deletions test/jdk/java/awt/print/PrinterJob/SecurityDialogTest.java
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2007, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2007, 2024, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
Expand All @@ -21,210 +21,110 @@
* questions.
*/

/**
import java.awt.Frame;
import java.awt.print.PageFormat;
import java.awt.print.PrinterJob;
import java.lang.reflect.InvocationTargetException;

import javax.print.PrintService;
import javax.print.attribute.HashPrintRequestAttributeSet;
import javax.print.attribute.PrintRequestAttributeSet;
import javax.swing.BorderFactory;
import javax.swing.Box;
import javax.swing.JComponent;
import javax.swing.JLabel;
import javax.swing.SwingUtilities;

/*
* @test
* @bug 4937672 5100706 6252456
* @key printer
* @run main/othervm/manual -Djava.security.manager=allow SecurityDialogTest
* @summary Verifies "Print to file" option is disable if reading/writing files
* is not allowed by Security Manager.
* @library /java/awt/regtesthelpers
* @build PassFailJFrame
* @run main/manual/othervm -Djava.security.manager=allow SecurityDialogTest
*/

import java.awt.* ;
import java.awt.print.* ;
import java.io.*;
import java.security.*;
import javax.print.*;
import javax.print.attribute.*;

public class SecurityDialogTest {
private static final String INSTRUCTIONS =
"This test brings up a native and cross-platform page and print dialogs.\n" +
"\n" +
"If the dialog has an option to save to file, the option ought " +
"to be disabled.\n" +
"\n" +
"Press the Pass button if the \"Print to file\" option was disabled in\n" +
"all the dialogs where it was present.\n" +
"Otherwise, press the Fail button.\n" +
"\n" +
"The dialogs should be displayed even when " +
"there is no queuePrintJob permission.";

private static JLabel dialogType;

public static void main(String[] args) throws Exception {
if (PrinterJob.lookupPrintServices().length == 0) {
throw new RuntimeException("Printer not configured or available.");
}

PassFailJFrame passFailJFrame = PassFailJFrame.builder()
.instructions(INSTRUCTIONS)
.splitUIBottom(SecurityDialogTest::createTestUI)
.rows((int) INSTRUCTIONS.lines().count() + 1)
.columns(45)
.build();

public static void main ( String args[] ) {

String[] instructions =
{
"You must have a printer available to perform this test.",
"This test brings up a native and cross-platform page and",
"print dialogs.",
"The dialogs should be displayed even when ",
"there is no queuePrintJob permission.",
"If the dialog has an option to save to file, the option ought",
"to be disabled if there is no read/write file permission.",
"You should test this by trying different policy files."
};

Sysout.createDialog( );
Sysout.printInstructions( instructions );
displayDialogs();

SecurityDialogTest pjc = new SecurityDialogTest() ;
passFailJFrame.awaitAndCheck();
}

private static JComponent createTestUI() {
dialogType = new JLabel(" ");

public SecurityDialogTest() {

PrinterJob pj = PrinterJob.getPrinterJob() ;

// Install a security manager which does not allow reading and
// writing of files.
//PrintTestSecurityManager ptsm = new PrintTestSecurityManager();
SecurityManager ptsm = new SecurityManager();

try {
System.setSecurityManager(ptsm);
} catch (SecurityException e) {
System.out.println("Could not run test - security exception");
}

try {
PrintJob pjob = Toolkit.getDefaultToolkit().getPrintJob(new Frame(), "Printing", null, null);
Sysout.println("If the value of pjob is null, the test fails.\n");
Sysout.println(" pjob = "+pjob);
} catch (SecurityException e) {
}

PrintService[] services = PrinterJob.lookupPrintServices();
for (int i=0; i<services.length; i++) {
System.out.println("SecurityDialogTest service "+i+" : "+services[i]);
}

PrintService defservice = pj.getPrintService();
System.out.println("SecurityDialogTest default service : "+defservice);

System.out.println("SecurityDialogTest native PageDialog ");
PageFormat pf1 = pj.pageDialog(new PageFormat());

System.out.println("SecurityDialogTest swing PageDialog ");
PrintRequestAttributeSet attributes = new HashPrintRequestAttributeSet();
PageFormat pf2 = pj.pageDialog(attributes);

// With the security manager installed, save to file should now
// be denied.
System.out.println("SecurityDialogTest native printDialog ");
pj.printDialog();
Box main = Box.createVerticalBox();
main.setBorder(BorderFactory.createEmptyBorder(8, 8, 8, 8));
main.add(new JLabel("Current Dialog:"));
main.add(Box.createVerticalStrut(4));
main.add(dialogType);
return main;
}

System.out.println("SecurityDialogTest swing printDialog ");
pj.printDialog(attributes);
}
private static void displayDialogs()
throws InterruptedException, InvocationTargetException {
final PrinterJob pj = PrinterJob.getPrinterJob();

// Install a security manager which does not allow reading and
// writing of files.
SecurityManager ptsm = new SecurityManager();
System.setSecurityManager(ptsm);

class PrintTestSecurityManager extends SecurityManager {
public void checkPackageAccess(String pkg) {
}
public void checkPropertyAccess(String key) {
PrintService[] services = PrinterJob.lookupPrintServices();
for (int i = 0; i < services.length; i++) {
System.out.println("SecurityDialogTest service " + i + " : " + services[i]);
}

}
System.out.println("SecurityDialogTest default service : " + pj.getPrintService());

}
class Sysout {
private static TestDialog dialog;

public static void createDialogWithInstructions( String[] instructions )
{
dialog = new TestDialog( new Frame(), "Instructions" );
dialog.printInstructions( instructions );
dialog.show();
println( "Any messages for the tester will display here." );
}

public static void createDialog( )
{
dialog = new TestDialog( new Frame(), "Instructions" );
String[] defInstr = { "Instructions will appear here. ", "" } ;
dialog.printInstructions( defInstr );
dialog.show();
println( "Any messages for the tester will display here." );
}
setDialogType("Native Page Dialog");
pj.pageDialog(new PageFormat());

setDialogType("Swing Page Dialog");
PrintRequestAttributeSet attributes = new HashPrintRequestAttributeSet();
pj.pageDialog(attributes);

public static void printInstructions( String[] instructions )
{
dialog.printInstructions( instructions );
}
// With the security manager installed, save to file should now
// be denied.
setDialogType("Native Print Dialog");
pj.printDialog();

setDialogType("Swing Print Dialog");
pj.printDialog(attributes);

public static void println( String messageIn )
{
dialog.displayMessage( messageIn );
setDialogType("Test completed");
}

}// Sysout class

/**
This is part of the standard test machinery. It provides a place for the
test instructions to be displayed, and a place for interactive messages
to the user to be displayed.
To have the test instructions displayed, see Sysout.
To have a message to the user be displayed, see Sysout.
Do not call anything in this dialog directly.
*/
class TestDialog extends Dialog {

TextArea instructionsText;
TextArea messageText;
int maxStringLength = 80;

//DO NOT call this directly, go through Sysout
public TestDialog( Frame frame, String name )
{
super( frame, name );
int scrollBoth = TextArea.SCROLLBARS_BOTH;
instructionsText = new TextArea( "", 15, maxStringLength, scrollBoth );
add( "North", instructionsText );

messageText = new TextArea( "", 5, maxStringLength, scrollBoth );
add("Center", messageText);

pack();

show();
}// TestDialog()

//DO NOT call this directly, go through Sysout
public void printInstructions( String[] instructions )
{
//Clear out any current instructions
instructionsText.setText( "" );

//Go down array of instruction strings

String printStr, remainingStr;
for( int i=0; i < instructions.length; i++ )
{
//chop up each into pieces maxSringLength long
remainingStr = instructions[ i ];
while( remainingStr.length() > 0 )
{
//if longer than max then chop off first max chars to print
if( remainingStr.length() >= maxStringLength )
{
//Try to chop on a word boundary
int posOfSpace = remainingStr.
lastIndexOf( ' ', maxStringLength - 1 );

if( posOfSpace <= 0 ) posOfSpace = maxStringLength - 1;

printStr = remainingStr.substring( 0, posOfSpace + 1 );
remainingStr = remainingStr.substring( posOfSpace + 1 );
}
//else just print
else
{
printStr = remainingStr;
remainingStr = "";
}

instructionsText.append( printStr + "\n" );

}// while

}// for

}//printInstructions()

//DO NOT call this directly, go through Sysout
public void displayMessage( String messageIn )
{
messageText.append( messageIn + "\n" );
private static void setDialogType(String type)
throws InterruptedException, InvocationTargetException {
SwingUtilities.invokeAndWait(() -> dialogType.setText(type));
}

}// TestDialog class
}

7 comments on commit 9f5ad43

@openjdk-notifier
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@luchenlin
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/backport jdk21u-dev

@openjdk
Copy link

@openjdk openjdk bot commented on 9f5ad43 Jul 2, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@luchenlin the backport was successfully created on the branch backport-luchenlin-9f5ad433-master in my personal fork of openjdk/jdk21u-dev. To create a pull request with this backport targeting openjdk/jdk21u-dev:master, just click the following link:

➡️ Create pull request

The title of the pull request is automatically filled in correctly and below you find a suggestion for the pull request body:

Hi all,

This pull request contains a backport of commit 9f5ad433 from the openjdk/jdk repository.

The commit being backported was authored by Renjith Kannath Pariyangad on 21 Mar 2024 and was reviewed by Alexey Ivanov and Tejesh R.

Thanks!

If you need to update the source branch of the pull then run the following commands in a local clone of your personal fork of openjdk/jdk21u-dev:

$ git fetch https://github.com/openjdk-bots/jdk21u-dev.git backport-luchenlin-9f5ad433-master:backport-luchenlin-9f5ad433-master
$ git checkout backport-luchenlin-9f5ad433-master
# make changes
$ git add paths/to/changed/files
$ git commit --message 'Describe additional changes made'
$ git push https://github.com/openjdk-bots/jdk21u-dev.git backport-luchenlin-9f5ad433-master

@luchenlin
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/backport jdk17u-dev

@luchenlin
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/backport jdk11u-dev

@openjdk
Copy link

@openjdk openjdk bot commented on 9f5ad43 Jul 2, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@luchenlin Could not automatically backport 9f5ad433 to openjdk/jdk17u-dev due to conflicts in the following files:

  • test/jdk/java/awt/print/PrinterJob/SecurityDialogTest.java

Please fetch the appropriate branch/commit and manually resolve these conflicts by using the following commands in your personal fork of openjdk/jdk17u-dev. Note: these commands are just some suggestions and you can use other equivalent commands you know.

# Fetch the up-to-date version of the target branch
$ git fetch --no-tags https://git.openjdk.org/jdk17u-dev.git master:master

# Check out the target branch and create your own branch to backport
$ git checkout master
$ git checkout -b backport-luchenlin-9f5ad433-master

# Fetch the commit you want to backport
$ git fetch --no-tags https://git.openjdk.org/jdk.git 9f5ad43358a4e209b4cd1c91bcc86b997f371548

# Backport the commit
$ git cherry-pick --no-commit 9f5ad43358a4e209b4cd1c91bcc86b997f371548
# Resolve conflicts now

# Commit the files you have modified
$ git add files/with/resolved/conflicts
$ git commit -m 'Backport 9f5ad43358a4e209b4cd1c91bcc86b997f371548'

Once you have resolved the conflicts as explained above continue with creating a pull request towards the openjdk/jdk17u-dev with the title Backport 9f5ad43358a4e209b4cd1c91bcc86b997f371548.

Below you can find a suggestion for the pull request body:

Hi all,

This pull request contains a backport of commit 9f5ad433 from the openjdk/jdk repository.

The commit being backported was authored by Renjith Kannath Pariyangad on 21 Mar 2024 and was reviewed by Alexey Ivanov and Tejesh R.

Thanks!

@openjdk
Copy link

@openjdk openjdk bot commented on 9f5ad43 Jul 2, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@luchenlin Could not automatically backport 9f5ad433 to openjdk/jdk11u-dev due to conflicts in the following files:

  • test/jdk/java/awt/print/PrinterJob/SecurityDialogTest.java

Please fetch the appropriate branch/commit and manually resolve these conflicts by using the following commands in your personal fork of openjdk/jdk11u-dev. Note: these commands are just some suggestions and you can use other equivalent commands you know.

# Fetch the up-to-date version of the target branch
$ git fetch --no-tags https://git.openjdk.org/jdk11u-dev.git master:master

# Check out the target branch and create your own branch to backport
$ git checkout master
$ git checkout -b backport-luchenlin-9f5ad433-master

# Fetch the commit you want to backport
$ git fetch --no-tags https://git.openjdk.org/jdk.git 9f5ad43358a4e209b4cd1c91bcc86b997f371548

# Backport the commit
$ git cherry-pick --no-commit 9f5ad43358a4e209b4cd1c91bcc86b997f371548
# Resolve conflicts now

# Commit the files you have modified
$ git add files/with/resolved/conflicts
$ git commit -m 'Backport 9f5ad43358a4e209b4cd1c91bcc86b997f371548'

Once you have resolved the conflicts as explained above continue with creating a pull request towards the openjdk/jdk11u-dev with the title Backport 9f5ad43358a4e209b4cd1c91bcc86b997f371548.

Below you can find a suggestion for the pull request body:

Hi all,

This pull request contains a backport of commit 9f5ad433 from the openjdk/jdk repository.

The commit being backported was authored by Renjith Kannath Pariyangad on 21 Mar 2024 and was reviewed by Alexey Ivanov and Tejesh R.

Thanks!

Please sign in to comment.