<AWT Dev> Please review changes in regression test /java/awt/TestArea/UsingWithMouse.java (second version of patch)
Pavel Tisnovsky
ptisnovs at redhat.com
Tue Jan 26 04:49:19 PST 2010
Artem Ananiev wrote:
>
> On 1/26/2010 2:57 PM, Pavel Tisnovsky wrote:
>> Artem Ananiev wrote:
>>>> I've added synchronization of scrolling using method
>>>> SunToolkit.realSync(), it seems to works perfectly on RHEL x86_64 +
>>>> Gnome and Fedora 10 i386 + Gnome. Thanks Anthony Petrov for his tip!
>>>
>>> the problem looks really, really strange... Util.waitForIdle() is
>>> implemented exactly the same way: as a call to realSync() - while you
>>> wrote that calling waitForIdle() didn't help.
>>>
>>> Please, postpone your fix (don't integrate into AWT gate repository)
>>> and check if Util.waitForIdle() does the job. realSync() is a
>>> low-level and private Sun's API, so I'd prefer having it in a single
>>> place (in Util) so we can change it easily, if necessary (e.g. when
>>> realSync() becomes public).
>>
>> Yes, you are right, Util.waitForIdle() simply calls realSync(). It is
>> interesting - without this sync (waifForIdle/realSync, does not matter
>> which I use) this test always fails on my machine (i.e. it does not
>> selects all lines of TextArea), with sync included it fails "only" in
>> circa 1/10 of its run. At this time, I don't plan to push this patch as
>> it isn't 100% correct.
>
> realSync() only deals with events - native and Java - but it doesn't
> cover things like native animations (e.g. on Vista/Seven with Aero
> enabled, a window is not minimized instantly, but can be animated, and
> realSync() couldn't be used to track this animation is over or in
> progress). That's why sometimes, in rare cases, a simple Thread.sleep()
> is a way to go.
Hmm, I see, the same problem can occur on Gnome+Compiz, for example. So
do I have to just add Thread.sleep() after each mouse move +
waitForIdle(), at least in this case? I tried that solution - whole text
in TextArea are selected during only 2-3 mouse moves due to autoscroll
feature (which is correct for this test case, IMHO).
>
> Thanks,
>
> Artem
>
>>> Thanks,
>>>
>>> Artem
>>>
>>>> This patch can be applied to OpenJDK7 too.
>>>>
>>>> Thanks in advance
>>>> Pavel Tisnovsky
>>>> Red Hat QA
>>>>
>>>>
>>
More information about the awt-dev
mailing list