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:
parent
e6c7f041f9
commit
7bd0087f96
@ -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");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user