Skip to content

Commit

Permalink
8315960: test/jdk/java/io/File/TempDirDoesNotExist.java leaves test f…
Browse files Browse the repository at this point in the history
…iles behind

Reviewed-by: lancea, djelinski, rriggs
  • Loading branch information
Brian Burkhalter committed Sep 22, 2023
1 parent f7578e8 commit 373cdf2
Showing 1 changed file with 94 additions and 59 deletions.
153 changes: 94 additions & 59 deletions test/jdk/java/io/File/TempDirDoesNotExist.java
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2022, 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
Expand All @@ -25,91 +25,126 @@
* @bug 8290313
* @library /test/lib
* @summary Produce warning when user specified java.io.tmpdir directory doesn't exist
* @run junit TempDirDoesNotExist
*/

import jdk.test.lib.process.ProcessTools;
import jdk.test.lib.process.OutputAnalyzer;
import jdk.test.lib.process.ProcessTools;

import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.Stream;

public class TempDirDoesNotExist {
final static String ioWarningMsg = "WARNING: java.io.tmpdir directory does not exist";
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.Arguments;
import org.junit.jupiter.params.provider.MethodSource;
import org.junit.jupiter.params.provider.ValueSource;
import static org.junit.jupiter.api.Assertions.assertEquals;

public static void main(String... args) throws Exception {
public class TempDirDoesNotExist {
final static String WARNING = "WARNING: java.io.tmpdir directory does not exist";

String userDir = System.getProperty("user.home");
String timeStamp = System.currentTimeMillis() + "";
String tempDir = Path.of(userDir,"non-existing-", timeStamp).toString();
private static final String USER_DIR = System.getProperty("user.home");

//
// This class is spawned to test combinations of parameters.
//
public static void main(String... args) throws IOException {
for (String arg : args) {
if (arg.equals("io")) {
try {
File.createTempFile("prefix", ".suffix");
} catch (Exception e) {
e.printStackTrace();
switch (arg) {
case "io" -> {
File file = null;
try {
file = File.createTempFile("prefix", ".suffix");
} catch (Exception e) {
e.printStackTrace();
} finally {
if (file != null && file.exists())
if (!file.delete())
throw new RuntimeException(file + " not deleted");
}
}
case "nio" -> {
Path path = null;
try {
path = Files.createTempFile("prefix", ".suffix");
} catch (Exception e) {
e.printStackTrace();
} finally {
if (path != null)
if (!Files.deleteIfExists(path))
throw new RuntimeException(path + " not deleted");
}
}
} else if (arg.equals("nio")) {
try {
Files.createTempFile("prefix", ".suffix");
} catch (Exception e) {
e.printStackTrace();
default -> {
throw new RuntimeException("unknown case: " + arg);
}
} else {
throw new Exception("unknown case: " + arg);
}
}
}

if (args.length == 0) {
// standard test with default setting for java.io.tmpdir
testMessageNotExist(0, ioWarningMsg, "TempDirDoesNotExist", "io");
testMessageNotExist(0, ioWarningMsg, "TempDirDoesNotExist", "nio");

// valid custom java.io.tmpdir
testMessageNotExist(0, ioWarningMsg, "-Djava.io.tmpdir=" + userDir,
"TempDirDoesNotExist", "io");
testMessageNotExist(0, ioWarningMsg, "-Djava.io.tmpdir=" + userDir,
"TempDirDoesNotExist", "nio");

// invalid custom java.io.tmpdir
testMessageExist(0, ioWarningMsg, "-Djava.io.tmpdir=" + tempDir,
"TempDirDoesNotExist", "io");
testMessageExist(0, ioWarningMsg, "-Djava.io.tmpdir=" + tempDir,
"TempDirDoesNotExist", "nio");
private static String tempDir() {
String timeStamp = String.valueOf(System.currentTimeMillis());
return Path.of(USER_DIR, "non-existing-", timeStamp).toString();
}

// test with security manager
testMessageExist(0, ioWarningMsg, "-Djava.io.tmpdir=" + tempDir
+ " -Djava.security.manager",
"TempDirDoesNotExist", "io");
public static Stream<Arguments> tempDirSource() {
return Stream.of(Arguments.of(List.of("-Djava.io.tmpdir=" + tempDir(),
"TempDirDoesNotExist", "io")),
Arguments.of(List.of("-Djava.io.tmpdir=" + tempDir(),
"TempDirDoesNotExist", "nio")),
Arguments.of(List.of("-Djava.io.tmpdir=" + tempDir() +
" -Djava.security.manager",
"TempDirDoesNotExist", "io")),
Arguments.of(List.of("-Djava.io.tmpdir=" + tempDir() +
" -Djava.security.manager",
"TempDirDoesNotExist", "nio")));
}

testMessageExist(0, ioWarningMsg, "-Djava.io.tmpdir=" + tempDir
+ " -Djava.security.manager",
"TempDirDoesNotExist", "nio");
public static Stream<Arguments> noTempDirSource() {
return Stream.of(Arguments.of(List.of("TempDirDoesNotExist", "io")),
Arguments.of(List.of("TempDirDoesNotExist", "nio")),
Arguments.of(List.of("-Djava.io.tmpdir=" + USER_DIR,
"TempDirDoesNotExist", "io")),
Arguments.of(List.of("-Djava.io.tmpdir=" + USER_DIR,
"TempDirDoesNotExist", "nio")));
}

// error message printed only once
testMessageCounter(0, "-Djava.io.tmpdir=" + tempDir,
"TempDirDoesNotExist", "io", "nio");
}
public static Stream<Arguments> counterSource() {
// standard test with default setting for java.io.tmpdir
return Stream.of(Arguments.of(List.of("-Djava.io.tmpdir=" + tempDir(),
"TempDirDoesNotExist",
"io", "nio")));
}

private static void testMessageExist(int exitValue, String errorMsg, String... options) throws Exception {
ProcessTools.executeTestJvm(options).shouldContain(errorMsg)
.shouldHaveExitValue(exitValue);
@ParameterizedTest
@MethodSource("tempDirSource")
public void existingMessage(List<String> options) throws Exception {
ProcessTools.executeTestJvm(options).shouldContain(WARNING)
.shouldHaveExitValue(0);
}

private static void testMessageNotExist(int exitValue, String errorMsg,String... options) throws Exception {
ProcessTools.executeTestJvm(options).shouldNotContain(errorMsg).shouldHaveExitValue(exitValue);
@ParameterizedTest
@MethodSource("noTempDirSource")
public void nonexistentMessage(List<String> options) throws Exception {
ProcessTools.executeTestJvm(options).shouldNotContain(WARNING)
.shouldHaveExitValue(0);
}

private static void testMessageCounter(int exitValue,String... options) throws Exception {
@ParameterizedTest
@MethodSource("counterSource")
public void messageCounter(List<String> options) throws Exception {
OutputAnalyzer originalOutput = ProcessTools.executeTestJvm(options);
List<String> list = originalOutput.asLines().stream().filter(line
-> line.equalsIgnoreCase(ioWarningMsg)).collect(Collectors.toList());
if (list.size() != 1 || originalOutput.getExitValue() != exitValue)
throw new Exception("counter of messages is not one, but " + list.size()
+ "\n" + originalOutput.asLines().toString() + "\n");
long count = originalOutput.asLines().stream().filter(
line -> line.equalsIgnoreCase(WARNING)).count();
assertEquals(1, count,
"counter of messages is not one, but " + count +
"\n" + originalOutput.asLines().toString());
int exitValue = originalOutput.getExitValue();
assertEquals(0, exitValue);
}
}
}

1 comment on commit 373cdf2

@openjdk-notifier
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.