RFR: JDK-8311983: ListView sometimes throws an IndexOutOfBoundsException [v2]

Andy Goryachev angorya at openjdk.org
Tue Aug 15 17:15:14 UTC 2023


On Thu, 3 Aug 2023 15:13:09 GMT, Marius Hanl <mhanl at openjdk.org> wrote:

>> An IOOBE was thrown when scrolling up via the trough (-> `VirtualScrollBar#adjustValue`).
>> This happened only when it has bigger cells than the viewport. 
>> If the the uppermost cell with the index 0 is only visible (although not completely scrolled to the top) and then an attempt is made to scroll up again, the `VirtualFlow` will try to scroll to the next cell, subtracting index 0 by 1, resulting in -1 -> IOOBE.
>> 
>> The code now guards against any under or overflow.
>> 
>> This is technically a regression from https://bugs.openjdk.org/browse/JDK-8173321
>> 
>> Note: While testing with very big cells, I found out that scrolling via the trough may not work after the first time. 
>> This is because the `VirtualFlow` still creates 2 cells, although only one can be visible at a time (at least when scrolling to the next cell) (and `VirtualScrollBar` does this check, which will never be true then: `firstVisibleCell == lastVisibleCell`). This is unrelated to this fix. I can create a ticket when I have more information.
>
> Marius Hanl has updated the pull request incrementally with three additional commits since the last revision:
> 
>  - JDK-8311983: remove JUnit5 import
>  - JDK-8311983: improve exception handling
>  - JDK-8311983: More tests

The change looks good, tested with the test app in the ticket and the Monkey Tester.

I wonder if we ought to consider some kind of `dirty` flag in the virtual layout to ensure that the layout is always performed when needed.  I understand this might require a larger change and it's definitely out of the scope for this PR.

modules/javafx.controls/src/test/java/test/javafx/scene/control/skin/VirtualFlowTest.java line 1790:

> 1788:         // Scroll down.
> 1789:         flow.shim_getVbar().adjustValue(0.9605263157894737);
> 1790:         // Scroll up.

FYI: adding `pulse()` here prevents the exception.

We seem to have a similar situation on line 739 (this particular test is ignored, but there quite a few `pulse()`s scattered in the test code:

        // NOTE Run this test without the pulse and it fails!
        pulse();

I wonder if there is something in the virtual flow that can detect when `flow.layout()` is needed and do it automatically.

modules/javafx.controls/src/test/java/test/javafx/scene/control/skin/VirtualFlowTest.java line 1799:

> 1797:     @Test
> 1798:     public void testScrollBarValueAdjustmentShouldScrollOneDown() {
> 1799:         flow = new VirtualFlowShim<>();

FYI: this test does not fail without the fix.  should it?

-------------

Marked as reviewed by angorya (Reviewer).

PR Review: https://git.openjdk.org/jfx/pull/1194#pullrequestreview-1579016585
PR Review Comment: https://git.openjdk.org/jfx/pull/1194#discussion_r1294877456
PR Review Comment: https://git.openjdk.org/jfx/pull/1194#discussion_r1294877019


More information about the openjfx-dev mailing list