8166262: failurehandler should not use jtreg internal API

Reviewed-by: sla, dsamersoff
This commit is contained in:
Igor Ignatyev 2016-09-20 16:56:04 +03:00
parent 6b4039c28a
commit e3124c170a
3 changed files with 60 additions and 6 deletions

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -26,8 +26,7 @@ package jdk.test.failurehandler.jtreg;
import com.sun.javatest.Harness; import com.sun.javatest.Harness;
import com.sun.javatest.Parameters; import com.sun.javatest.Parameters;
import com.sun.javatest.TestResult; import com.sun.javatest.TestResult;
import com.sun.javatest.regtest.RegressionParameters; import com.sun.javatest.InterviewParameters;
import com.sun.javatest.regtest.OS;
import jdk.test.failurehandler.*; import jdk.test.failurehandler.*;
import java.io.File; import java.io.File;
@ -119,7 +118,7 @@ public class GatherDiagnosticInfoObserver implements Harness.Observer {
@Override @Override
public void startingTestRun(Parameters params) { public void startingTestRun(Parameters params) {
// TODO find a better way to get JDKs // TODO find a better way to get JDKs
RegressionParameters rp = (RegressionParameters) params; InterviewParameters rp = (InterviewParameters) params;
Map<?,?> map = new HashMap<>(); Map<?,?> map = new HashMap<>();
rp.save(map); rp.save(map);
compileJdk = (String) map.get("regtest.compilejdk"); compileJdk = (String) map.get("regtest.compilejdk");

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -23,7 +23,6 @@
package jdk.test.failurehandler.jtreg; package jdk.test.failurehandler.jtreg;
import com.sun.javatest.regtest.OS;
import com.sun.javatest.regtest.TimeoutHandler; import com.sun.javatest.regtest.TimeoutHandler;
import jdk.test.failurehandler.*; import jdk.test.failurehandler.*;

View File

@ -0,0 +1,56 @@
/*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package jdk.test.failurehandler.jtreg;
// Stripped down version of jtreg internal class com.sun.javatest.regtest.config.OS
class OS {
public final String family;
private static OS current;
public static OS current() {
if (current == null) {
String name = System.getProperty("os.name");
current = new OS(name);
}
return current;
}
private OS(String name) {
if (name.startsWith("Linux")) {
family = "linux";
} else if (name.startsWith("Mac") || name.startsWith("Darwin")) {
family = "mac";
} else if (name.startsWith("SunOS") || name.startsWith("Solaris")) {
family = "solaris";
} else if (name.startsWith("Windows")) {
family = "windows";
} else {
// use first word of name
family = name.replaceFirst("^([^ ]+).*", "$1");
}
}
}