Commit 7be414f
authored
fix: refresh now surfaces externally-generated files in new pakages (#1026)
* Fix #914: refresh now surfaces externally-generated files in new packages
The source package-root load only did a shallow (DEPTH_ONE) refresh, so files
written to disk by external generators into brand-new packages never appeared in
the Java Projects view, even after Refresh.
Manual Refresh now deep-refreshes (DEPTH_INFINITE) and closes the package root so
the Java Model re-enumerates its package-fragment list. Auto-refresh passes the
changed resource URI to the server via PackageParams.syncPaths, which scopes the
refresh to the nearest existing ancestor subtree instead of the whole source
root, falling back to a full deep refresh when a path cannot be resolved.
- PackageParams: add syncPaths field + accessors
- PackageCommand: targeted refresh branch + findNearestExistingResource helper
- packageRootNode: stash pending sync paths, snapshot/clear in loadData
- syncHandler: onDidCreate stashes the created URI (cycle-safe NodeKind check)
- add E2E plans for manual deep refresh and targeted auto-refresh
* test: make #914 E2E assertions deterministic to fix CI false negatives
CI runs the autotest harness with the LLM screenshot judge enabled, which the
local --no-llm runs skipped. Four state-check steps sat on a wait action while
asserting a state that was already true (the package/class had appeared in an
earlier refresh step). The LLM judge diffed the before/after screenshots, saw no
visual delta, and failed the steps -- even though the deterministic verifyTreeItem
DOM assertion passed. This produced a spurious 18/20 in CI vs 20/20 locally.
Remove the natural-language �erify: field from those pure state-check steps and
rely solely on the deterministic �erifyTreeItem assertion, which is the actual
behaviour under test. Steps where a visible change genuinely occurs within their
own window keep their �erify:.
* test: drop LLM verify on file-write/refresh steps and trim comments (#914)
The Windows-UI run still failed (19/20): the LLM screenshot judge could not
confirm the insertLineInFile step because the written file is not visible in the
collapsed Explorer (autoReveal off), a flaky judgment that passed on Linux but
failed on Windows. Remove �erify: from all steps with no reliable visual
signal (file writes, manual refresh, view focus); keep it only on expandTreeItem
steps, which produce a clear visual change. Deterministic verifyTreeItem remains
the real assertion. Also trim the verbose header/inline comments.
* test: add deterministic negative baseline to #914 plans
Each plan only asserted the new package was PRESENT after refresh, never that it
was ABSENT before — the missing "before" half of the before/after comparison.
Add a deterministic verifyTreeItem (visible: false) baseline proving the package
does not exist prior to the file write, so the later appearance is a genuine
refresh-driven transition rather than a pre-existing or leftover node. Uses the
DOM check (waitForTreeItemGone), so no LLM-judge flakiness. Verified locally:
manual 21/21, auto-refresh 16/16.
* fix: address PR review - restore syncPaths on failure, dedup refresh targets
- packageRootNode: restore the pending syncPaths snapshot if getPackageData rejects so a transient server error does not drop a targeted refresh
- PackageCommand: dedup resolved refresh targets via LinkedHashSet so multiple files in the same new package only refresh the subtree once
- e2e plans: align Maven section id to lowercase 'maven' for consistency1 parent da10f1c commit 7be414f
6 files changed
Lines changed: 390 additions & 11 deletions
File tree
- jdtls.ext/com.microsoft.jdtls.ext.core/src/com/microsoft/jdtls/ext/core
- src
- views
- test/e2e-plans
Lines changed: 101 additions & 3 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
16 | 16 | | |
17 | 17 | | |
18 | 18 | | |
| 19 | + | |
19 | 20 | | |
20 | 21 | | |
21 | 22 | | |
| |||
371 | 372 | | |
372 | 373 | | |
373 | 374 | | |
374 | | - | |
| 375 | + | |
375 | 376 | | |
376 | 377 | | |
377 | 378 | | |
| |||
508 | 509 | | |
509 | 510 | | |
510 | 511 | | |
| 512 | + | |
| 513 | + | |
| 514 | + | |
| 515 | + | |
511 | 516 | | |
512 | | - | |
| 517 | + | |
| 518 | + | |
| 519 | + | |
| 520 | + | |
| 521 | + | |
| 522 | + | |
| 523 | + | |
| 524 | + | |
| 525 | + | |
| 526 | + | |
| 527 | + | |
| 528 | + | |
| 529 | + | |
| 530 | + | |
| 531 | + | |
| 532 | + | |
| 533 | + | |
| 534 | + | |
| 535 | + | |
| 536 | + | |
| 537 | + | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
| 543 | + | |
| 544 | + | |
| 545 | + | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
| 565 | + | |
| 566 | + | |
| 567 | + | |
513 | 568 | | |
514 | 569 | | |
515 | 570 | | |
| |||
599 | 654 | | |
600 | 655 | | |
601 | 656 | | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
602 | 661 | | |
603 | 662 | | |
604 | 663 | | |
605 | 664 | | |
606 | | - | |
| 665 | + | |
607 | 666 | | |
608 | 667 | | |
609 | 668 | | |
610 | 669 | | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
| 694 | + | |
| 695 | + | |
| 696 | + | |
| 697 | + | |
| 698 | + | |
| 699 | + | |
| 700 | + | |
| 701 | + | |
| 702 | + | |
| 703 | + | |
| 704 | + | |
| 705 | + | |
| 706 | + | |
| 707 | + | |
| 708 | + | |
611 | 709 | | |
Lines changed: 18 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| 14 | + | |
| 15 | + | |
14 | 16 | | |
15 | 17 | | |
16 | 18 | | |
| |||
31 | 33 | | |
32 | 34 | | |
33 | 35 | | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
34 | 44 | | |
35 | 45 | | |
36 | 46 | | |
| |||
97 | 107 | | |
98 | 108 | | |
99 | 109 | | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
100 | 118 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
90 | 90 | | |
91 | 91 | | |
92 | 92 | | |
93 | | - | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
94 | 105 | | |
95 | 106 | | |
96 | 107 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
16 | 16 | | |
17 | 17 | | |
18 | 18 | | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
19 | 27 | | |
20 | 28 | | |
21 | 29 | | |
| |||
25 | 33 | | |
26 | 34 | | |
27 | 35 | | |
28 | | - | |
29 | | - | |
30 | | - | |
31 | | - | |
32 | | - | |
33 | | - | |
34 | | - | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
35 | 58 | | |
36 | 59 | | |
37 | 60 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
0 commit comments