RFR: 8269556: sun/tools/jhsdb/JShellHeapDumpTest.java fails with RuntimeException 'JShellToolProvider' missing from stdout/stderr [v2]

Chris Plummer cjplummer at openjdk.java.net
Fri Dec 10 20:30:41 UTC 2021


> The test searches for "JShellToolProvider" in the main thread's stack trace, which is pulled from an SA heap dump. Typically the main thread is blocked in Object.wait(), so SA can determine its stack trace. However, the wait has a 100ms timeout, so the thread does periodically wake up and does a few things before waiting again. If SA tries to get the stack trace while the thread is active, it may not be able to, and this causes the test to fail. I determined this only happens about 1 in 5000-10000 runs. So as a fix I'm allowing the test to do one retry. That should make it extremely unlikely that we ever see this failure again. I also bumped up the amount of time the test waits before doing the heap dump from 2 seconds to 4 just to make absolutely sure the main thread is fully started before doing the heap dump.

Chris Plummer has updated the pull request incrementally with one additional commit since the last revision:

  Renamed isRetry to allowRetry.

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

Changes:
  - all: https://git.openjdk.java.net/jdk/pull/6795/files
  - new: https://git.openjdk.java.net/jdk/pull/6795/files/65e14883..aaa915b3

Webrevs:
 - full: https://webrevs.openjdk.java.net/?repo=jdk&pr=6795&range=01
 - incr: https://webrevs.openjdk.java.net/?repo=jdk&pr=6795&range=00-01

  Stats: 6 lines in 1 file changed: 0 ins; 0 del; 6 mod
  Patch: https://git.openjdk.java.net/jdk/pull/6795.diff
  Fetch: git fetch https://git.openjdk.java.net/jdk pull/6795/head:pull/6795

PR: https://git.openjdk.java.net/jdk/pull/6795


More information about the serviceability-dev mailing list