RFR: JDK-8212028: Use run-test makefile framework for testing in Oracle's Mach5
Magnus Ihse Bursie
magnus.ihse.bursie at oracle.com
Fri Oct 12 08:37:07 UTC 2018
Hi Erik,
Thank you for preserving through this, so we finally can move to 100%
run-test!
On 2018-10-12 00:29, Erik Joelsson wrote:
> Hello,
>
> (adding serviceability-dev and hotspot-dev for test changes)
>
> Bug: https://bugs.openjdk.java.net/browse/JDK-8212028
>
> Webrev: http://cr.openjdk.java.net/~erikj/8212028/webrev.01/index.html
> (From ihse-runtestprebuilt-branch in jdk-sandbox)
Build changes look good. And I agree with the solution to add longer
timeout to individual tests.
>
> In order to fully adopt the new run-test framework, we need to switch
> over the automated and distributed testing system at Oracle to the new
> framework. To get this to work, there are number of issues that needed
> to be fixed. Here follows a brief explanation, see bug for more details.
>
> For RunTest.gmk and related makefiles there are a number of minor
> tweaks to support all the necessary control variables that are
> currently used for the old test makefiles, as well as correcting some
> test setup settings.
>
> In addition to that, some tests also needed to be modified:
>
> Timeouts
> The current default timeoutFactor in the makefiles is 4. However, the
> old Mach5 executor overrides that to 10. I don't think it should
> dabble with such things and leave it to the makefiles, the user, or a
> specific job definition, so with the new run-test executor, it no
> longer does. This means many tests now have a much shorter effective
> timeout. Because of this, we need to increase the timeout on some that
> are now prone to timing out. I have run tier1-5 a few times to try and
> find these and added /timeout=300 (which will result in the same
> effective timeout as before) when specific tests seemed problematic.
>
> test/hotspot/jtreg/runtime/appcds/jvmti/InstrumentationTest.java
> This test spawns a child process and tries to locate it using the
> attach api, by looking for a unique token in the command line string
> of the spawned JVM. The problem is that the command line string it
> gets from the attach api is truncated and the token is last on the
> command line. This normally works well, but the arguments before it
> are 3 files, with full absolute paths inside the jtreg work directory.
> With Mach5 we have pretty deep work directories, and with run-test, we
> make them even deeper. This unfortunately trips the limit and the test
> fails. I have fixed this by reordering the arguments to the child
> process.
... but I'm not sure I understand this. Is it a command-line length
we're hitting? If so, how can reordering the arguments solve anything? I
understand why this can preserve the token, but will not one of the
paths be cut of instead?
/Magnus
>
> /Erik
>
More information about the build-dev
mailing list