8307105: JFileChooser InvalidPathException when selecting some system folders on Windows

Reviewed-by: aivanov, abhiscxk, dnguyen
This commit is contained in:
Tejesh R 2023-06-02 04:29:33 +00:00
parent 101bf2290d
commit 325940b091
3 changed files with 97 additions and 10 deletions

View File

@ -37,7 +37,6 @@ import java.beans.PropertyChangeListener;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.nio.file.Files;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Hashtable; import java.util.Hashtable;
@ -709,8 +708,7 @@ public class BasicFileChooserUI extends FileChooserUI {
&& ((File)objects[0]).isDirectory() && ((File)objects[0]).isDirectory()
&& chooser.isTraversable(((File)objects[0])) && chooser.isTraversable(((File)objects[0]))
&& (useSetDirectory && (useSetDirectory
|| (!fsv.isFileSystem(((File)objects[0])) || (!fsv.isFileSystem((File)objects[0])))) {
&& !Files.isSymbolicLink(((File)objects[0]).toPath())))) {
setDirectorySelected(true); setDirectorySelected(true);
setDirectory(((File)objects[0])); setDirectory(((File)objects[0]));
} else { } else {
@ -720,7 +718,7 @@ public class BasicFileChooserUI extends FileChooserUI {
boolean isDir = f.isDirectory(); boolean isDir = f.isDirectory();
if ((chooser.isFileSelectionEnabled() && !isDir) if ((chooser.isFileSelectionEnabled() && !isDir)
|| (chooser.isDirectorySelectionEnabled() || (chooser.isDirectorySelectionEnabled()
&& (fsv.isFileSystem(f) || Files.isSymbolicLink(f.toPath())) && fsv.isFileSystem(f)
&& isDir)) { && isDir)) {
fList.add(f); fList.add(f);
} }
@ -742,12 +740,8 @@ public class BasicFileChooserUI extends FileChooserUI {
setDirectorySelected(true); setDirectorySelected(true);
setDirectory(file); setDirectory(file);
if (usesSingleFilePane) { if (usesSingleFilePane) {
if (Files.isSymbolicLink(file.toPath())) {
chooser.setSelectedFile(file);
} else {
chooser.setSelectedFile(null); chooser.setSelectedFile(null);
} }
}
} else { } else {
setDirectorySelected(false); setDirectorySelected(false);
if (file != null) { if (file != null) {

View File

@ -856,10 +856,18 @@ final class Win32ShellFolder2 extends ShellFolder {
/** /**
* @return Whether this shell folder is a link * @return Whether this shell folder is a link
* @implNote Returns {@code true} for {@code .lnk} shortcuts only.
* For <i>symbolic links</i> and <i>junctions</i>, it returns
* {@code false} even though {@code IShellFolder} returns
* {@code true} now. It is a workaround for easier handling of
* symbolic links and junctions.
*/ */
public boolean isLink() { public boolean isLink() {
if (cachedIsLink == null) { if (cachedIsLink == null) {
cachedIsLink = hasAttribute(ATTRIB_LINK); cachedIsLink = hasAttribute(ATTRIB_LINK)
&& (!isFileSystem()
|| getPath().toLowerCase().endsWith(".lnk"));
} }
return cachedIsLink; return cachedIsLink;

View File

@ -0,0 +1,85 @@
/*
* Copyright (c) 2023, 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.
*/
import java.awt.BorderLayout;
import javax.swing.JFrame;
import javax.swing.JFileChooser;
import javax.swing.SwingUtilities;
import javax.swing.WindowConstants;
import java.lang.reflect.InvocationTargetException;
/*
* @test
* @bug 8307105
* @key headful
* @requires (os.family == "windows")
* @library /java/awt/regtesthelpers
* @build PassFailJFrame
* @summary Test to check if the certain windows like "This PC",
* "Library", "Network" does not throw Invalid Path Exception on selection.
* @run main/manual FileChooserInvalidPathExceptionTest
*/
public class FileChooserInvalidPathExceptionTest {
static JFrame frame;
static JFileChooser jfc;
static PassFailJFrame passFailJFrame;
public static void main(String[] args) throws Exception {
SwingUtilities.invokeAndWait(() -> {
try {
initialize();
} catch (Exception e) {
throw new RuntimeException(e);
}
});
passFailJFrame.awaitAndCheck();
}
static void initialize() throws Exception {
//Initialize the components
final String INSTRUCTIONS = """
Instructions to Test:
1. Navigate to any windows specific folders like My PC/Libraries/
Network.
2. Select and traverse through those folders.
3. On click of the mentioned folder if InvalidPathException
occurs does not occur then test is PASS.
""";
frame = new JFrame("JFileChooser IPE test");
jfc = new JFileChooser();
passFailJFrame = new PassFailJFrame("Test Instructions", INSTRUCTIONS, 5L, 8, 40);
PassFailJFrame.addTestWindow(frame);
PassFailJFrame.positionTestWindow(frame, PassFailJFrame.Position.HORIZONTAL);
frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
jfc.setControlButtonsAreShown(false);
jfc.setDialogType(JFileChooser.CUSTOM_DIALOG);
frame.add(jfc, BorderLayout.CENTER);
frame.pack();
frame.setVisible(true);
}
}