8186009: tools launcher test AddExportsAndOpensInManifest.java fails intermittently: AccessDeniedException

Unique jar file names for every test case

Reviewed-by: alanb
This commit is contained in:
Andrey Nazarov 2018-01-26 12:16:08 -08:00
parent e6c7f041f9
commit 7bd0087f96

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2016, 2018, 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
@ -32,6 +32,7 @@
* manifest of a main application JAR * manifest of a main application JAR
*/ */
import java.lang.reflect.Method;
import java.nio.file.Files; import java.nio.file.Files;
import java.nio.file.Path; import java.nio.file.Path;
import java.nio.file.Paths; import java.nio.file.Paths;
@ -41,6 +42,7 @@ import java.util.jar.Manifest;
import jdk.testlibrary.OutputAnalyzer; import jdk.testlibrary.OutputAnalyzer;
import jdk.testlibrary.ProcessTools; import jdk.testlibrary.ProcessTools;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import static org.testng.Assert.*; import static org.testng.Assert.*;
@ -48,6 +50,15 @@ import static org.testng.Assert.*;
@Test @Test
public class AddExportsAndOpensInManifest { public class AddExportsAndOpensInManifest {
private String testName;
private int testCaseNum;
@BeforeMethod
public void getTestName(Method m){
testName = m.getName();
testCaseNum = 0;
}
/** /**
* Package Test1 and Test2 into a JAR file with the given attributes * Package Test1 and Test2 into a JAR file with the given attributes
* in the JAR manifest, then execute the JAR file with `java -jar`. * in the JAR manifest, then execute the JAR file with `java -jar`.
@ -67,7 +78,7 @@ public class AddExportsAndOpensInManifest {
} }
// create the JAR file with Test1 and Test2 // create the JAR file with Test1 and Test2
Path jarfile = Paths.get("test.jar"); Path jarfile = Paths.get(String.format("%s-%s.jar", testName, ++testCaseNum));
Files.deleteIfExists(jarfile); Files.deleteIfExists(jarfile);
Path classes = Paths.get(System.getProperty("test.classes", "")); Path classes = Paths.get(System.getProperty("test.classes", ""));
@ -172,5 +183,4 @@ public class AddExportsAndOpensInManifest {
attrs = "Main-Class=Test1,Add-Opens=java.base/jdk.internal.DoesNotExit"; attrs = "Main-Class=Test1,Add-Opens=java.base/jdk.internal.DoesNotExit";
runExpectingFail(attrs, "IllegalAccessError"); runExpectingFail(attrs, "IllegalAccessError");
} }
} }