Commit ed12c66
[VFS-862] Fix ON_RESOLVE triggering refresh on internal navigation (#761)
* [VFS-862] Fix ON_RESOLVE triggering refresh on internal navigation
CacheStrategy.ON_RESOLVE is intended to refresh files when the user
resolves them via the public API. However, internal navigation methods
(getParent, getRoot, getChildren child resolution, symlink resolution)
also called fileSystem.resolveFile(), triggering ON_RESOLVE refreshes
on files the user never asked to refresh.
This became a severe regression after refresh() was changed to
unconditionally clear FtpFileObject.childMap: each child's getParent()
refreshed the parent, clearing its childMap, forcing a new FTP LIST
command per child. A directory with N files produced ~N LIST commands
instead of 1.
Fix:
- Add resolveFileInternal() that skips the ON_RESOLVE refresh. All
internal navigation call sites use it instead of resolveFile().
- After a fresh directory listing, FTP and SFTP providers propagate
metadata to cached child objects in-place, preserving object identity.
This establishes a clear contract: cached state is used until the user
explicitly calls refresh() or resolves via the public API. Internal
navigation never triggers server operations.
Tests:
- FtpGetChildrenListCommandTest: verifies findFiles() on a directory
with 50 files issues exactly 1 LIST command with ON_RESOLVE.
- SftpGetChildrenListCommandTest: verifies refresh + findFiles()
returns fresh children reflecting filesystem changes.
* [VFS-862] Disable HTTP persistent connections in Jackrabbit 1.x tests
Jackrabbit 1.x bundles Jetty 6.x which does not drain unconsumed
request bodies before sending error responses (e.g. 404) on persistent
connections, violating HTTP/1.1 requirements. This leaves stale request
bytes that corrupt the next request on a reused connection.
The resolveFileInternal change in getParent() removed an extra PROPFIND
request to the parent directory that used to happen between the child's
PROPFIND (404) and the child's PUT. That extra request happened to flush
the stale bytes from the connection. Without it, the server reads the
112-byte PROPFIND XML request body as the PUT file content.
Fix: add Connection: close to the test HttpClient configuration so
each request uses a fresh connection.
Jetty 9.4+ handles this correctly (see jetty#651, jetty#4117, jetty#6168).
Jackrabbit 2 tests pass without changes. No production code modified.
* [VFS-862] Remove SFTP test that passes without the fix
The SFTP test cannot distinguish the fix from the original ON_RESOLVE
behavior because SFTP's doListChildrenResolved() pushes metadata to
each child via setStat() immediately after resolution. The ON_RESOLVE
refresh clears attrs, but setStat() repopulates it right after — same
server traffic either way. The optimization is purely client-side.
The FTP test remains and definitively proves the fix (82 LISTs without
the fix, 1 LIST with).
* Add comment.
---------
Co-authored-by: Gary Gregory <garydgregory@users.noreply.github.com>1 parent 2ab6374 commit ed12c66
6 files changed
Lines changed: 259 additions & 12 deletions
File tree
- commons-vfs2-jackrabbit1/src/test/java/org/apache/commons/vfs2/provider/webdav/test
- commons-vfs2/src
- main/java/org/apache/commons/vfs2/provider
- ftp
- sftp
- test/java/org/apache/commons/vfs2/provider/ftp
Lines changed: 22 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
36 | 36 | | |
37 | 37 | | |
38 | 38 | | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
39 | 42 | | |
40 | 43 | | |
41 | 44 | | |
| |||
284 | 287 | | |
285 | 288 | | |
286 | 289 | | |
287 | | - | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
288 | 309 | | |
289 | 310 | | |
290 | 311 | | |
| |||
Lines changed: 21 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1306 | 1306 | | |
1307 | 1307 | | |
1308 | 1308 | | |
1309 | | - | |
| 1309 | + | |
1310 | 1310 | | |
1311 | 1311 | | |
1312 | 1312 | | |
| |||
1805 | 1805 | | |
1806 | 1806 | | |
1807 | 1807 | | |
1808 | | - | |
| 1808 | + | |
| 1809 | + | |
| 1810 | + | |
| 1811 | + | |
| 1812 | + | |
| 1813 | + | |
| 1814 | + | |
| 1815 | + | |
| 1816 | + | |
| 1817 | + | |
| 1818 | + | |
| 1819 | + | |
| 1820 | + | |
| 1821 | + | |
| 1822 | + | |
| 1823 | + | |
| 1824 | + | |
| 1825 | + | |
| 1826 | + | |
| 1827 | + | |
1809 | 1828 | | |
1810 | 1829 | | |
1811 | 1830 | | |
| |||
Lines changed: 34 additions & 5 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
377 | 377 | | |
378 | 378 | | |
379 | 379 | | |
380 | | - | |
| 380 | + | |
381 | 381 | | |
382 | 382 | | |
383 | 383 | | |
| |||
525 | 525 | | |
526 | 526 | | |
527 | 527 | | |
528 | | - | |
| 528 | + | |
529 | 529 | | |
530 | 530 | | |
531 | | - | |
532 | | - | |
| 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 | + | |
533 | 561 | | |
534 | 562 | | |
535 | 563 | | |
| |||
561 | 589 | | |
562 | 590 | | |
563 | 591 | | |
564 | | - | |
| 592 | + | |
| 593 | + | |
565 | 594 | | |
566 | 595 | | |
567 | 596 | | |
| |||
Lines changed: 23 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
501 | 501 | | |
502 | 502 | | |
503 | 503 | | |
| 504 | + | |
504 | 505 | | |
505 | | - | |
| 506 | + | |
| 507 | + | |
| 508 | + | |
| 509 | + | |
| 510 | + | |
| 511 | + | |
| 512 | + | |
| 513 | + | |
| 514 | + | |
| 515 | + | |
| 516 | + | |
| 517 | + | |
| 518 | + | |
| 519 | + | |
| 520 | + | |
| 521 | + | |
| 522 | + | |
| 523 | + | |
| 524 | + | |
| 525 | + | |
| 526 | + | |
506 | 527 | | |
507 | 528 | | |
508 | 529 | | |
| |||
530 | 551 | | |
531 | 552 | | |
532 | 553 | | |
533 | | - | |
| 554 | + | |
534 | 555 | | |
535 | 556 | | |
536 | 557 | | |
| |||
Lines changed: 7 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
346 | 346 | | |
347 | 347 | | |
348 | 348 | | |
349 | | - | |
| 349 | + | |
350 | 350 | | |
351 | 351 | | |
352 | | - | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
353 | 358 | | |
354 | 359 | | |
355 | 360 | | |
| |||
commons-vfs2/src/test/java/org/apache/commons/vfs2/provider/ftp/FtpGetChildrenListCommandTest.java
Lines changed: 152 additions & 0 deletions
| 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 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
0 commit comments