On Fri, 23 Feb 2024 21:55:15 GMT, Chris Plummer <cjplum...@openjdk.org> wrote:

> PerfMapTest.java issues the Compiler.perfmap jcmd with a filename argument to 
> write the perfmap to. It does this in 3 different modes. 2 of the modes 
> result in a perfmap file being left in the tmp directory that is not removed 
> after the test executes (and should be removed). The 3rd mode creates the 
> perfmap file in the directory specified by the test.dir property, and is ok 
> to leave the file there. I've added code to delete the /tmp files that are 
> created.
> 
> I did a bit of extra testing by hand. I created `/tmp/perf-<pid>.map` as 
> root. As expected the Files.deleteIfExists() call threw an exception due to 
> the lack of permissions to delete the file. However, I then realized the file 
> had a size of 0, which means the test was not even doing a proper job of 
> testing that the perfrmap jcmd was working. In other words, the test should 
> have failed long before getting to the Files.deleteIfExists(), so I added a 
> size check to make sure it fails when the file is not written to.

Looks good but posted a question.

test/hotspot/jtreg/serviceability/dcmd/compiler/PerfMapTest.java line 103:

> 101:         } while(Files.exists(path));
> 102:         run(new JMXExecutor(), "Compiler.perfmap " + path.toString(), 
> path);
> 103:     }

Q: It is not clear why the file is not deleted in this case. Do I miss anything?

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

Marked as reviewed by sspitsyn (Reviewer).

PR Review: https://git.openjdk.org/jdk/pull/17992#pullrequestreview-1912339995
PR Review Comment: https://git.openjdk.org/jdk/pull/17992#discussion_r1509721128

Reply via email to