JDK-5064013 : Regression test test/java/awt/Focus/TypeAhead/TestFocusFreeze.java fails
  • Type: Bug
  • Component: client-libs
  • Sub-Component: java.awt
  • Affected Version: 5.0
  • Priority: P3
  • Status: Resolved
  • Resolution: Fixed
  • OS: windows_2000
  • CPU: x86
  • Submitted: 2004-06-16
  • Updated: 2006-06-22
  • Resolved: 2005-11-26
The Version table provides details related to the release that this issue/RFE will be addressed.

Unresolved : Release in which this issue/RFE will be addressed.
Resolved: Release in which this issue/RFE has been resolved.
Fixed : Release in which this issue/RFE has been fixed. The release containing this fix may be available for download as an Early Access Release or a General Availability Release.

To download the current JDK release, click here.
JDK 6
6 b62Fixed
Related Reports
Relates :  
Relates :  
Relates :  
Relates :  
Relates :  
Relates :  
Relates :  
Relates :  
Description
Name: icR10030			Date: 06/16/2004


Filed By       : J2SE-SQA [###@###.###
JDK            : JDK1.5.0-b55
Testbase       : Regression-test
Platform[s]    : Windows 2000 Pro
switch/Mode    : -client
Falling test[s]:
         java/awt/KeyboardFocusmanager/TypeAhead/TestDialogTypeAhead.html

Regression-test java/awt/KeyboardFocusmanager/TypeAhead/TestDialogTypeAhead.html test fails with JDK1.5.0-b55
The test from b54 build passes in jdk1.5.0-b54/b55
See also bug 5048934

Test source location:
=====================
/java/re/jdk/1.5.0/promoted/all/b55/ws/j2se/test/java/awt/KeyboardFocusmanager/TypeAhead/TestDialogTypeAhead.html

jtr file location:
==================
/net/jtgb4u4c.sfbay/export/sail15/results.2/tiger/b55/regtest/win32/Windows_2000_Pro_linux-2/workDir/test/java/awt/KeyboardFocusmanager/TypeAhead/TestDialogTypeAhead.jtr

How to reproduce:
=================
Run the following script (you may need to change its variables)

--- script start ---
#!/bin/sh
RESULT_DIR=`pwd`
WORK_DIR=$RESULT_DIR/workDir/test
REPORT_DIR=$RESULT_DIR/reportDir


#Paths in SWAN
#
# Note: to run the script on Windows you need /net mapped on N: drive (net use N: \sm-usca<your building code>-01
et)
# If you're outside of SCA campus please consult with http://orbit.central/iwork/tools/filemgr/windows_filemgr.html
# to get a list of SAMBA servers nearest to your location
#
#net use N: \sm-usca14-01
et
#

JT_HOME="n:/koori.sfbay/onestop/jct-tools/3.1.2/archive/fcs/binaries"
JEMMY_JAR="n:/jdk.sfbay/export/jpse04/Jemmy/jemmy.jar"
JAVA_HOME="n:/koori.sfbay/onestop/jdk/1.5.0/promoted/all/b55/binaries/windows-i586"
TEST_BASE_PATH="n:/koori.sfbay/onestop/jdk/1.5.0/promoted/all/b55/ws/j2se/test"

#Alternative paths for the NSK site:
#JT_HOME="h:/java/jct"
#JEMMY_JAR="$JT_HOME/jemmy/jemmy.jar"
#JAVA_HOME="h:/java/jdk1.5.0/win32"
#TEST_BASE_PATH="h:/java/regtest.tiger/test"


TESTVMOPTS="-client"
CLASSPATH="$JT_HOME/classes;$JT_HOME/lib/javatest.jar;$JT_HOME/lib/jtreg.jar"

TEST="java/awt/KeyboardFocusmanager/TypeAhead/TestDialogTypeAhead.html"

mkdir -p $WORK_DIR/scratch 2>&1
mkdir -p $WORK_DIR/jtData 2>&1
mkdir -p $REPORT_DIR 2>&1

#rm $WORK_DIR/jtData/ResultCache.jtw 2>&1

cd $WORK_DIR/scratch

$JAVA_HOME/bin/java -showversion -server -cp $CLASSPATH -DenvVars=TESTJAVAHOME=$JAVA_HOME,TESTVMOPTS=$TESTVMOPTS,windir=$windir,SystemRoot=$SystemRoot,PATH=${SHELL%/*},CPAPPEND=$JEMMY_JAR,TZ=,LC_ALL=en_US,LC_CTYPE=en_US,LANG=en_US,LPDEST=   -DlocalHost=`uname -n` -Dprogram=jtreg com.sun.javatest.regtest.Main -v default -batch -params  -w "$WORK_DIR" -r "$REPORT_DIR" -t "$TEST_BASE_PATH" "$TEST_BASE_PATH/$TEST"

--- script end ---

Script output:
==============

Test output (jtr part):
=======================
----------System.out:(0/0)----------
----------System.err:(15/1135)----------
b is shown
b is focused
java.awt.event.KeyEvent[KEY_PRESSED,keyCode=32,keyText=Space,keyChar=' ',keyLocation=KEY_LOCATION_STANDARD] on button0
java.awt.event.KeyEvent[KEY_TYPED,keyCode=0,keyText=Unknown keyCode: 0x0,keyChar=' ',keyLocation=KEY_LOCATION_UNKNOWN] on button0
java.awt.event.KeyEvent[KEY_RELEASED,keyCode=32,keyText=Space,keyChar=' ',keyLocation=KEY_LOCATION_STANDARD] on button0
B pressed
java.awt.event.KeyEvent[KEY_PRESSED,keyCode=32,keyText=Space,keyChar=' ',keyLocation=KEY_LOCATION_STANDARD] on dialog0
java.awt.event.KeyEvent[KEY_TYPED,keyCode=0,keyText=Unknown keyCode: 0x0,keyChar=' ',keyLocation=KEY_LOCATION_UNKNOWN] on dialog0
java.awt.event.KeyEvent[KEY_RELEASED,keyCode=32,keyText=Space,keyChar=' ',keyLocation=KEY_LOCATION_STANDARD] on dialog0
Ok got focus
java.lang.RuntimeException: Type-ahead doesn't work
	at TestDialogTypeAhead.start(TestDialogTypeAhead.java:152)
	at com.sun.javatest.regtest.AppletWrapper$AppletThread.run(AppletWrapper.java:133)
	at java.lang.Thread.run(Thread.java:595)
STATUS:Failed.Applet thread threw exception: java.lang.RuntimeException: Type-ahead doesn't work
result: Failed. Execution failed: Applet thread threw exception: java.lang.RuntimeException: Type-ahead doesn't work


test result: Failed. Execution failed: Applet thread threw exception: java.lang.RuntimeException: Type-ahead doesn't work



Specific machine info:
======================
Hostname: linux-2
OS: Windows 2000 Pro



======================================================================
It appeared that in the context of this CR another regtest failure has been resolved.
That regtest was created for 6291992. It failed on Windows. Here's it:

   test/java/awt/Focus/TypeAhead/TestFocusFreeze.java

So, I've changed the synopsis accordingly. The old synopsis looked as follows:
- Regression test java/awt/KeyboardFocusmanager/TypeAhead/TestDialogType fails.
This regtest was also failing that has been fixed in 6382750.

Comments
EVALUATION The fix has been partially rolled back (see 6396785 for details). A new CR is open to track the issue - 6447537.
18-07-2006

EVALUATION I could reproduce the test failing using jdk6.0 b53 on Windows (works fine on Linux). I have performed some investigation of the failing: 1) WPeerButton shouldn't execute the ActionEvent posting on event handler thread. As you can see from the test the robot triggers key events as soon as ActionEvent listener will raise it. We expect that this events will be delayed until the dialog/button becomes the focus owner. The reasons of this expectation are following: X = ActionEvent.getWhen() X+delta = KeyEvents.getWhen() EDT: AE processing: mostRecentEventTime.setTime(X) EDT: AE processing: dialog.setVisible -> enqueueKeyEvents(mostRecentEventTime.getTime()) EDT: KE processing: mostRecentEventTime.setTime(X+delta) EDT: KE processing: event is added to enqueuedKeyEvents to invoke later Actually, the ActionEvent time is not the mostRecentEventTime since to post this event we create InvocationEvent (see WButtonPeer.java). And the InvocationEvent timestamp equals System.currentTimeMillis (>X, but this events is processed before the ActionEvent). That's why enqueueKeyEvents.after equals the InvocationEvent.getWhen(). 2) delta can be equals 0. In other words, KeyEvents will be generated by robot immediately (reproducible only on Windows/reproducible sometimes). According to current implementation the event is added to queue only if it happens after the marker time (see DKFM.java typeAheadAssertions). Sounds reasonable to update this inqualities (add, remove: > to >= ). 3) In the regression test we expect that the deferred key events will be dispatched to the button1 component. But the source of the first FOCUS_GAIN events is the dialog component (reproducible only on Windows). So the test should be revised as well.
06-10-2005

EVALUATION Name: osR10079 Date: 06/17/2004 we should investigate this problem in next release. ======================================================================
17-09-2004