8340329: (fs) Message of NotLinkException thrown by FIles.readSymbolicLink does not include file name (win)
Reviewed-by: alanb
This commit is contained in:
parent
3bb8de3145
commit
2ada313cdd
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2008, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2008, 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
|
||||||
@ -86,7 +86,7 @@ class WindowsLinkSupport {
|
|||||||
x.rethrowAsIOException(path);
|
x.rethrowAsIOException(path);
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
return readLinkImpl(handle);
|
return readLinkImpl(path, handle);
|
||||||
} finally {
|
} finally {
|
||||||
CloseHandle(handle);
|
CloseHandle(handle);
|
||||||
}
|
}
|
||||||
@ -297,16 +297,18 @@ class WindowsLinkSupport {
|
|||||||
* Returns target of a symbolic link given the handle of an open file
|
* Returns target of a symbolic link given the handle of an open file
|
||||||
* (that should be a link).
|
* (that should be a link).
|
||||||
*/
|
*/
|
||||||
private static String readLinkImpl(long handle) throws IOException {
|
private static String readLinkImpl(WindowsPath path, long handle)
|
||||||
|
throws IOException
|
||||||
|
{
|
||||||
int size = MAXIMUM_REPARSE_DATA_BUFFER_SIZE;
|
int size = MAXIMUM_REPARSE_DATA_BUFFER_SIZE;
|
||||||
try (NativeBuffer buffer = NativeBuffers.getNativeBuffer(size)) {
|
try (NativeBuffer buffer = NativeBuffers.getNativeBuffer(size)) {
|
||||||
try {
|
try {
|
||||||
DeviceIoControlGetReparsePoint(handle, buffer.address(), size);
|
DeviceIoControlGetReparsePoint(handle, buffer.address(), size);
|
||||||
} catch (WindowsException x) {
|
} catch (WindowsException x) {
|
||||||
// FIXME: exception doesn't have file name
|
String pathname = path.getPathForExceptionMessage();
|
||||||
if (x.lastError() == ERROR_NOT_A_REPARSE_POINT)
|
if (x.lastError() == ERROR_NOT_A_REPARSE_POINT)
|
||||||
throw new NotLinkException(null, null, x.errorString());
|
throw new NotLinkException(pathname, null, x.errorString());
|
||||||
x.rethrowAsIOException((String)null);
|
x.rethrowAsIOException(pathname + ": " + x.errorString());
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -342,8 +344,8 @@ class WindowsLinkSupport {
|
|||||||
|
|
||||||
int tag = (int)unsafe.getLong(buffer.address() + OFFSETOF_REPARSETAG);
|
int tag = (int)unsafe.getLong(buffer.address() + OFFSETOF_REPARSETAG);
|
||||||
if (tag != IO_REPARSE_TAG_SYMLINK) {
|
if (tag != IO_REPARSE_TAG_SYMLINK) {
|
||||||
// FIXME: exception doesn't have file name
|
String pathname = path.getPathForExceptionMessage();
|
||||||
throw new NotLinkException(null, null, "Reparse point is not a symbolic link");
|
throw new NotLinkException(pathname, null, "Reparse point is not a symbolic link");
|
||||||
}
|
}
|
||||||
|
|
||||||
// get offset and length of target
|
// get offset and length of target
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2008, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2008, 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
|
||||||
@ -22,7 +22,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* @test
|
/* @test
|
||||||
* @bug 4313887 6838333 6863864
|
* @bug 4313887 6838333 6863864 8340329
|
||||||
* @summary Unit test for java.nio.file.Files createSymbolicLink,
|
* @summary Unit test for java.nio.file.Files createSymbolicLink,
|
||||||
* readSymbolicLink, and createLink methods
|
* readSymbolicLink, and createLink methods
|
||||||
* @library ..
|
* @library ..
|
||||||
@ -45,7 +45,7 @@ public class Links {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Exercise createSymbolicLink and readLink methods
|
* Exercise createSymbolicLink and readSymbolicLink methods
|
||||||
*/
|
*/
|
||||||
static void testSymLinks(Path dir) throws IOException {
|
static void testSymLinks(Path dir) throws IOException {
|
||||||
final Path link = dir.resolve("link");
|
final Path link = dir.resolve("link");
|
||||||
@ -131,6 +131,27 @@ public class Links {
|
|||||||
Files.deleteIfExists(mydir);
|
Files.deleteIfExists(mydir);
|
||||||
Files.deleteIfExists(link);
|
Files.deleteIfExists(link);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check message of NotLinkException
|
||||||
|
try {
|
||||||
|
Files.createDirectory(mydir);
|
||||||
|
|
||||||
|
try {
|
||||||
|
Path mytarget = Files.readSymbolicLink(mydir);
|
||||||
|
} catch (NotLinkException expected) {
|
||||||
|
String filename = mydir.getFileName().toString();
|
||||||
|
String message = expected.getMessage();
|
||||||
|
boolean okay = message.contains(filename);
|
||||||
|
if (!okay) {
|
||||||
|
System.err.println("Message \"" + message + "\"" +
|
||||||
|
" does not contain the filename \"" +
|
||||||
|
filename + "\"");
|
||||||
|
assertTrue(okay);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
Files.deleteIfExists(mydir);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user