8328957: Update PKCS11Test.java to not use hardcoded path
Reviewed-by: mbalao, rhalade
This commit is contained in:
parent
375bfac8e7
commit
16576b87b7
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2024, 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
|
||||||
@ -54,9 +54,7 @@ import java.util.Properties;
|
|||||||
import java.util.ServiceConfigurationError;
|
import java.util.ServiceConfigurationError;
|
||||||
import java.util.ServiceLoader;
|
import java.util.ServiceLoader;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.regex.Matcher;
|
import java.util.stream.Stream;
|
||||||
import java.util.regex.Pattern;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
import javax.crypto.SecretKey;
|
import javax.crypto.SecretKey;
|
||||||
import javax.crypto.spec.SecretKeySpec;
|
import javax.crypto.spec.SecretKeySpec;
|
||||||
@ -261,19 +259,13 @@ public abstract class PKCS11Test {
|
|||||||
|
|
||||||
static Path getNSSLibPath(String library) throws Exception {
|
static Path getNSSLibPath(String library) throws Exception {
|
||||||
String osid = getOsId();
|
String osid = getOsId();
|
||||||
String nssLibDir = fetchNssLib(osid);
|
Path libraryName = Path.of(System.mapLibraryName(library));
|
||||||
if (nssLibDir == null) {
|
Path nssLibPath = fetchNssLib(osid, libraryName);
|
||||||
|
if (nssLibPath == null) {
|
||||||
throw new SkippedException("Warning: unsupported OS: " + osid
|
throw new SkippedException("Warning: unsupported OS: " + osid
|
||||||
+ ", please initialize NSS library location, skipping test");
|
+ ", please initialize NSS library location, skipping test");
|
||||||
}
|
}
|
||||||
|
return nssLibPath;
|
||||||
String libraryName = System.mapLibraryName(library);
|
|
||||||
Path libPath = Paths.get(nssLibDir).resolve(libraryName);
|
|
||||||
if (!Files.exists(libPath)) {
|
|
||||||
throw new SkippedException("NSS library \"" + libraryName + "\" was not found in " + nssLibDir);
|
|
||||||
}
|
|
||||||
|
|
||||||
return libPath;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String getOsId() {
|
private static String getOsId() {
|
||||||
@ -735,42 +727,42 @@ public abstract class PKCS11Test {
|
|||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String fetchNssLib(String osId) {
|
private static Path fetchNssLib(String osId, Path libraryName) {
|
||||||
switch (osId) {
|
switch (osId) {
|
||||||
case "Windows-amd64-64":
|
case "Windows-amd64-64":
|
||||||
return fetchNssLib(WINDOWS_X64.class);
|
return fetchNssLib(WINDOWS_X64.class, libraryName);
|
||||||
|
|
||||||
case "MacOSX-x86_64-64":
|
case "MacOSX-x86_64-64":
|
||||||
return fetchNssLib(MACOSX_X64.class);
|
return fetchNssLib(MACOSX_X64.class, libraryName);
|
||||||
|
|
||||||
case "MacOSX-aarch64-64":
|
case "MacOSX-aarch64-64":
|
||||||
return fetchNssLib(MACOSX_AARCH64.class);
|
return fetchNssLib(MACOSX_AARCH64.class, libraryName);
|
||||||
|
|
||||||
case "Linux-amd64-64":
|
case "Linux-amd64-64":
|
||||||
if (Platform.isOracleLinux7()) {
|
if (Platform.isOracleLinux7()) {
|
||||||
throw new SkippedException("Skipping Oracle Linux prior to v8");
|
throw new SkippedException("Skipping Oracle Linux prior to v8");
|
||||||
} else {
|
} else {
|
||||||
return fetchNssLib(LINUX_X64.class);
|
return fetchNssLib(LINUX_X64.class, libraryName);
|
||||||
}
|
}
|
||||||
|
|
||||||
case "Linux-aarch64-64":
|
case "Linux-aarch64-64":
|
||||||
if (Platform.isOracleLinux7()) {
|
if (Platform.isOracleLinux7()) {
|
||||||
throw new SkippedException("Skipping Oracle Linux prior to v8");
|
throw new SkippedException("Skipping Oracle Linux prior to v8");
|
||||||
} else {
|
} else {
|
||||||
return fetchNssLib(LINUX_AARCH64.class);
|
return fetchNssLib(LINUX_AARCH64.class, libraryName);
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String fetchNssLib(Class<?> clazz) {
|
private static Path fetchNssLib(Class<?> clazz, Path libraryName) {
|
||||||
String path = null;
|
Path path = null;
|
||||||
try {
|
try {
|
||||||
path = ArtifactResolver.resolve(clazz).entrySet().stream()
|
Path p = ArtifactResolver.resolve(clazz).entrySet().stream()
|
||||||
.findAny().get().getValue() + File.separator + "nss"
|
.findAny().get().getValue();
|
||||||
+ File.separator + "lib" + File.separator;
|
path = findNSSLibrary(p, libraryName);
|
||||||
} catch (ArtifactResolverException e) {
|
} catch (ArtifactResolverException | IOException e) {
|
||||||
Throwable cause = e.getCause();
|
Throwable cause = e.getCause();
|
||||||
if (cause == null) {
|
if (cause == null) {
|
||||||
System.out.println("Cannot resolve artifact, "
|
System.out.println("Cannot resolve artifact, "
|
||||||
@ -784,6 +776,16 @@ public abstract class PKCS11Test {
|
|||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static Path findNSSLibrary(Path path, Path libraryName) throws IOException {
|
||||||
|
try(Stream<Path> files = Files.find(path, 10,
|
||||||
|
(tp, attr) -> tp.getFileName().equals(libraryName))) {
|
||||||
|
|
||||||
|
return files.findAny()
|
||||||
|
.orElseThrow(() -> new SkippedException(
|
||||||
|
"NSS library \"" + libraryName + "\" was not found in " + path));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public abstract void main(Provider p) throws Exception;
|
public abstract void main(Provider p) throws Exception;
|
||||||
|
|
||||||
protected boolean skipTest(Provider p) {
|
protected boolean skipTest(Provider p) {
|
||||||
|
Loading…
Reference in New Issue
Block a user