212565afd7
6844313: New I/O: File timestamps should be represented by a FileTime rather than a long+TimeUnit Reviewed-by: sherman
118 lines
4.0 KiB
Java
118 lines
4.0 KiB
Java
/*
|
|
* Copyright 2008-2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
|
* CA 95054 USA or visit www.sun.com if you need additional information or
|
|
* have any questions.
|
|
*/
|
|
|
|
/* @test
|
|
* @bug 4313887 6838333
|
|
* @summary Unit test for java.nio.file.Files for miscellenous cases not
|
|
* covered by other tests
|
|
* @library ..
|
|
*/
|
|
|
|
import java.nio.file.*;
|
|
import java.io.IOException;
|
|
import java.util.*;
|
|
|
|
public class Misc {
|
|
|
|
static void npeExpected() {
|
|
throw new RuntimeException("NullPointerException expected");
|
|
}
|
|
|
|
public static void main(String[] args) throws IOException {
|
|
|
|
// -- Files.createDirectories --
|
|
|
|
Path dir = TestUtil.createTemporaryDirectory();
|
|
try {
|
|
// no-op
|
|
Files.createDirectories(dir);
|
|
|
|
// create one directory
|
|
Path subdir = dir.resolve("a");
|
|
Files.createDirectories(subdir);
|
|
if (!subdir.exists())
|
|
throw new RuntimeException("directory not created");
|
|
|
|
// create parents
|
|
subdir = subdir.resolve("b/c/d");
|
|
Files.createDirectories(subdir);
|
|
if (!subdir.exists())
|
|
throw new RuntimeException("directory not created");
|
|
|
|
// existing file is not a directory
|
|
Path file = dir.resolve("x").createFile();
|
|
try {
|
|
Files.createDirectories(file);
|
|
throw new RuntimeException("failure expected");
|
|
} catch (FileAlreadyExistsException x) { }
|
|
try {
|
|
Files.createDirectories(file.resolve("y"));
|
|
throw new RuntimeException("failure expected");
|
|
} catch (IOException x) { }
|
|
|
|
} finally {
|
|
TestUtil.removeAll(dir);
|
|
}
|
|
|
|
// --- NullPointerException --
|
|
|
|
try {
|
|
Files.probeContentType(null);
|
|
npeExpected();
|
|
} catch (NullPointerException e) {
|
|
}
|
|
try {
|
|
Files.walkFileTree(null, EnumSet.noneOf(FileVisitOption.class),
|
|
Integer.MAX_VALUE, new SimpleFileVisitor<Path>(){});
|
|
npeExpected();
|
|
} catch (NullPointerException e) {
|
|
}
|
|
try {
|
|
Files.walkFileTree(Paths.get("."), null, Integer.MAX_VALUE,
|
|
new SimpleFileVisitor<Path>(){});
|
|
npeExpected();
|
|
} catch (NullPointerException e) {
|
|
}
|
|
try {
|
|
Files.walkFileTree(Paths.get("."), EnumSet.noneOf(FileVisitOption.class),
|
|
-1, new SimpleFileVisitor<Path>(){});
|
|
throw new RuntimeException("IllegalArgumentExpected expected");
|
|
} catch (IllegalArgumentException e) {
|
|
}
|
|
try {
|
|
Set<FileVisitOption> opts = new HashSet<FileVisitOption>(1);
|
|
opts.add(null);
|
|
Files.walkFileTree(Paths.get("."), opts, Integer.MAX_VALUE,
|
|
new SimpleFileVisitor<Path>(){});
|
|
npeExpected();
|
|
} catch (NullPointerException e) {
|
|
}
|
|
try {
|
|
Files.walkFileTree(Paths.get("."), EnumSet.noneOf(FileVisitOption.class),
|
|
Integer.MAX_VALUE, null);
|
|
npeExpected();
|
|
} catch (NullPointerException e) {
|
|
}
|
|
}
|
|
}
|