<AWT Dev> [7] Review Request for 8047961: [TESTBUG] closed/java/awt/Focus/ActivateFocusTest/ActivateFocusTest.html fails intermittently

Anton V. Tarasov anton.tarasov at oracle.com
Mon Nov 17 11:01:14 UTC 2014


Hi Oleg,

Glad to hear from you :)

On 14.11.2014 18:24, Oleg Sukhodolsky wrote:
> Sorry to interrupt you but since I do know the test let me say that
> requestFocus() is an important part of the test,
> if you are going to replace it with requestFocusInWindow() you
> (effectively) remove it from list of regression tests.
> Please check 4369903 bug for more information.

In the bug I see the description of why the infinite loop happens and a suggestion to use 
requestFocusInWindow to prevent it. From my point of view, the behavior is expected taking into 
account the asynchronous nature of java focus.

By default, when a toplevel window gains activation, KeyboardFocusManager requests focus in it by 
means of calling the requestFocusInWindow method. Thus, the test case creates an artificial 
situation with unclear goals. It doesn't seem to reflect a real use case (I can see the bug was 
filed by an internal engineer, not refering to any customer or user application). In case a 
developer wants to alter the component receiving focus at the toplevels's activation, he/she can 
achieve this by means of customizing the focus traversal policy, for instance.

The javadoc [1] for the JComponent.requestFocus method warns developers about its usage:

<<Note that the use of this method is discouraged because its behavior is platform dependent. 
Instead we recommend the use of requestFocusInWindow().>>

What I'm trying to say is that we'd rather avoid hacking the focus subsystem in order to just solve 
the infinite loop problem.

However, originally the reporter of the bug complains about the following:

<<Setting focus during window activation often sends focus to the wrong place, or to multiple places.>>

This behavior is incorrect, indeed. But we can verify it with the test case. When a component gains 
focus we can check that:

1. it is the current focus owner reported by KFM, and the current focused window is its container
2. the opposite component has lost focus prior to that (that is, every FOCUS_GAINED precedes a 
FOCUS_LOST received by the opposite component)
3. the same about the WINDOW_LOST_FOCUS/WINDOW_GAINED_FOCUS pair

The test should be ready for the infinite loop and I can suggest to simply stop requesting focus 
after a couple of iterations.

This could be a compromize. What do you think, Oleg, Mikhail?

Thanks,
Anton.

[1] https://docs.oracle.com/javase/8/docs/api/javax/swing/JComponent.html#requestFocus--

>
> Regards, Oleg.
>
> P.S. feel free to ask more questions if you need.
>
> On Fri, Nov 14, 2014 at 5:07 PM, Anton V. Tarasov
> <anton.tarasov at oracle.com> wrote:
>> Hi Mikhail,
>>
>> Looks fine for me. Thanks! This was an old one... Do you have any plans to
>> fix it in 8/9 as well?
>>
>> Regards,
>> Anton.
>>
>>
>> On 14.11.2014 18:57, mikhail cherkasov wrote:
>>> Hello all,
>>>
>>> Could you please review a simple fix of closed test, the test was moved to
>>> open repo
>>> and requestFocus was replaced requestFocusInWindow.
>>>
>>> Because "requestFocus" cause infinite war for focus between two windows,
>>> however this
>>> behavior is correct and doesn't violet spec.
>>>
>>> [TESTBUG] closed/java/awt/Focus/ActivateFocusTest/ActivateFocusTest.html
>>> fails intermittently
>>> bug: https://bugs.openjdk.java.net/browse/JDK-8047961
>>> Webrev: http://cr.openjdk.java.net/~mcherkas/8047961/webrev.00/
>>>
>>> Thanks,
>>> Mikhail.
>>>



More information about the awt-dev mailing list