// This test is a "main" test as applets would need Runtime permission // "queuePrintJob".
publicclass Orient implements Printable {
privatestaticvoid init()
{ //*** Create instructions for the user here ***
String[] instructions =
{ "On-screen inspection is not possible for this printing-specific", "test therefore its only output is three printed pages.", "To be able to run this test it is required to have a default", "printer configured in your user environment.", "", "Visual inspection of the printed page is needed. A passing", "test will print three pages each containing a large oval ", "with the text describing the orientation: PORTRAIT, LANDSCAPE", "or REVERSE_LANDSCAPE, inside of it. The first page will ", "be emitted in portait orientation, the second page in landscape ", "orientation and the third page in reverse-landscape orientation. ", "On each page the oval will be wholly within the imageable area ", "of the page. In a failing test the oval on the third page ", "will be clipped against the imageable area.", "Axes will indicate the direction of increasing X and Y"
};
Sysout.createDialog( );
Sysout.printInstructions( instructions );
publicstaticvoid main( String args[] ) throws InterruptedException
{
mainThread = Thread.currentThread(); try
{
init();
} catch( TestPassedException e )
{ //The test passed, so just return from main and harness will // interepret this return as a pass return;
} //At this point, neither test passed nor test failed has been // called -- either would have thrown an exception and ended the // test, so we know we have multiple threads.
//Test involves other threads, so sleep and wait for them to // called pass() or fail() try
{ Thread.sleep( sleepTime ); //Timed out, so fail the test thrownew RuntimeException( "Timed out after " + sleepTime/1000 + " seconds" );
} catch (InterruptedException e)
{ if( ! testGeneratedInterrupt ) throw e;
//reset flag in case hit this code more than once for some reason (just safety)
testGeneratedInterrupt = false; if ( theTestPassed == false )
{ thrownew RuntimeException( failureMessage );
}
}
publicstaticsynchronizedvoid pass()
{
Sysout.println( "The test passed." );
Sysout.println( "The test is over, hit Ctl-C to stop Java VM" ); //first check if this is executing in main thread if ( mainThread == Thread.currentThread() )
{ //Still in the main thread, so set the flag just for kicks, // and throw a test passed exception which will be caught // and end the test.
theTestPassed = true; thrownew TestPassedException();
} //pass was called from a different thread, so set the flag and interrupt // the main thead.
theTestPassed = true;
testGeneratedInterrupt = true;
mainThread.interrupt();
}//pass()
publicstaticsynchronizedvoid fail()
{ //test writer didn't specify why test failed, so give generic
fail( "it just plain failed! :-)" );
}
publicstaticsynchronizedvoid fail( String whyFailed )
{
Sysout.println( "The test failed: " + whyFailed );
Sysout.println( "The test is over, hit Ctl-C to stop Java VM" ); //check if this called from main thread if ( mainThread == Thread.currentThread() )
{ //If main thread, fail now 'cause not sleeping thrownew RuntimeException( whyFailed );
}
theTestPassed = false;
testGeneratedInterrupt = true;
failureMessage = whyFailed;
mainThread.interrupt();
}//fail()
}// class Orient
//This exception is used to exit from any level of call nesting // when it's determined that the test has passed, and immediately // end the test. class TestPassedException extends RuntimeException
{
}
//*********** End Standard Test Machinery Section **********
//************ Begin classes defined for the test ****************
// make listeners in a class defined here, and instantiate them in init()
/* Example of a class which may be written as part of a test classNewClassimplementsanInterface { staticintnewVar=0;
publicvoideventDispatched(AWTEvente) { //Counting events to see if we get enough eventCount++;
if(eventCount==20) { //got enough events, so pass
Orient.pass(); } elseif(tries==20) { //tried too many times without getting enough events so fail
Orient.fail(); }
}// eventDispatched()
}// NewClass class
*/
//************** End classes defined for the test *******************
TextArea instructionsText;
TextArea messageText; int maxStringLength = 80;
Panel buttonP = new Panel();
Button passB = new Button( "pass" );
Button failB = new Button( "fail" );
//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 );
passB = new Button( "pass" );
passB.setActionCommand( "pass" );
passB.addActionListener( this );
buttonP.add( "East", passB );
failB = new Button( "fail" );
failB.setActionCommand( "fail" );
failB.addActionListener( this );
buttonP.add( "West", failB );
add( "South", buttonP );
pack();
show();
}// TestDialog()
//DO NOT call this directly, go through Sysout publicvoid 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 );
//DO NOT call this directly, go through Sysout publicvoid displayMessage( String messageIn )
{
messageText.append( messageIn + "\n" );
}
//catch presses of the passed and failed buttons. //simply call the standard pass() or fail() static methods of //Orient publicvoid actionPerformed( ActionEvent e )
{ if( e.getActionCommand() == "pass" )
{
Orient.pass();
} else
{
Orient.fail();
}
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.