3789983e89
Reviewed-by: darcy, ihse
170 lines
6.4 KiB
Java
170 lines
6.4 KiB
Java
/*
|
|
* Copyright (c) 2011, 2016, 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.
|
|
*/
|
|
|
|
/*
|
|
* @test
|
|
* @bug 6381464 8153666
|
|
* @summary Test the custom simple formatter output
|
|
*
|
|
* @run main/othervm SimpleFormatterFormat
|
|
*/
|
|
|
|
import java.io.*;
|
|
import java.util.logging.*;
|
|
import java.util.regex.*;
|
|
|
|
public class SimpleFormatterFormat {
|
|
private static final String key = "java.util.logging.SimpleFormatter.format";
|
|
private static final String origFormat = System.getProperty(key);
|
|
private static final PrintStream err = System.err;
|
|
public static void main(String[] args) throws Exception {
|
|
try {
|
|
File dir = new File(System.getProperty("user.dir", "."));
|
|
File log = new File(dir, "simpleformat.txt");
|
|
java.nio.file.Files.deleteIfExists(log.toPath());
|
|
PrintStream logps = new PrintStream(log);
|
|
System.setProperty(key, "%3$s:%4$s: %5$s [%1$tc] source: %2$s%6$s%n");
|
|
writeLogRecords(logps);
|
|
checkLogRecords(log);
|
|
} finally {
|
|
if (origFormat == null) {
|
|
System.clearProperty(key);
|
|
} else {
|
|
System.setProperty(key, origFormat);
|
|
}
|
|
System.setErr(err);
|
|
}
|
|
}
|
|
|
|
private static String[] loggers = new String[] {
|
|
"test.foo",
|
|
"test.foo",
|
|
"test.bar",
|
|
"test.bar",
|
|
"test.bar",
|
|
"test.bar"
|
|
};
|
|
private static String[] messages = new String[] {
|
|
"severe hello world",
|
|
"warning lost connection",
|
|
"info welcome",
|
|
"warning beware of traps",
|
|
"warning { {ok7} }",
|
|
// keep exception logging as last test case to avoid having
|
|
// to skip the exception stack trace in the output
|
|
"warning exception thrown"
|
|
};
|
|
private static void writeLogRecords(PrintStream logps) throws Exception {
|
|
try {
|
|
System.setErr(logps);
|
|
|
|
Logger foo = Logger.getLogger("test.foo");
|
|
foo.log(Level.SEVERE, "{0} {1} {2}", new Object[] {"severe", "hello", "world"});
|
|
foo.warning(messages[1]);
|
|
|
|
Logger bar = Logger.getLogger("test.bar");
|
|
bar.finest("Dummy message");
|
|
bar.info(messages[2]);
|
|
bar.log(Level.WARNING, "{0}", new Object[] { messages[3] });
|
|
bar.log(Level.WARNING, "warning '{' '{'{7}} }", new Object[] {"ok", "ok1", "ok2", "ok3", "ok4", "ok5", "ok6", "ok7", "ok8", "ok9", "ok10"});
|
|
|
|
// Keep this one last - as it also prints the exception stack trace...
|
|
bar.log(Level.WARNING, messages[messages.length-1], new IllegalArgumentException());
|
|
} finally {
|
|
logps.flush();
|
|
logps.close();
|
|
System.setErr(err);
|
|
}
|
|
}
|
|
|
|
private static void checkLogRecords(File log) throws Exception {
|
|
System.out.println("Checking log records in file: " + log);
|
|
Pattern p = Pattern.compile("([\\.a-zA-Z:]+) (.*) \\[.*\\] source: (.*)");
|
|
|
|
try (FileInputStream in = new FileInputStream(log);
|
|
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
|
|
) {
|
|
String line;
|
|
int i = 0;
|
|
while (i < messages.length &&
|
|
(line = reader.readLine()) != null) {
|
|
String expectedLogger = loggers[i];
|
|
String expectedMsg = messages[i];
|
|
i++;
|
|
|
|
line = line.trim();
|
|
System.out.println(line);
|
|
|
|
Matcher m = p.matcher(line);
|
|
if (!m.matches()) {
|
|
throw new RuntimeException("Unexpected output format: " + line);
|
|
}
|
|
if (m.groupCount() != 3) {
|
|
throw new RuntimeException("Unexpected group count = " +
|
|
m.groupCount());
|
|
}
|
|
// verify logger name and level
|
|
String[] ss = m.group(1).split(":");
|
|
int len = ss.length;
|
|
if (len != 2) {
|
|
throw new RuntimeException("Unexpected logger name and level" +
|
|
m.group(1));
|
|
}
|
|
|
|
verify(expectedLogger, expectedMsg, ss[0], ss[1], m.group(2), m.group(3));
|
|
}
|
|
|
|
// expect IllegalArgumentException following it
|
|
line = reader.readLine().trim();
|
|
if (!line.equals("java.lang.IllegalArgumentException")) {
|
|
throw new RuntimeException("Invalid line: " + line);
|
|
}
|
|
}
|
|
}
|
|
|
|
private static void verify(String expectedLogger, String expectedMsg,
|
|
String logger, String level,
|
|
String msg, String source) {
|
|
if (!logger.equals(expectedLogger)) {
|
|
throw new RuntimeException("Unexpected logger: " + logger);
|
|
}
|
|
if (!msg.equals(expectedMsg)) {
|
|
throw new RuntimeException("Unexpected message: " + msg);
|
|
}
|
|
|
|
String[] ss = expectedMsg.split("\\s+");
|
|
String expectedLevel = ss[0].toUpperCase();
|
|
if (!level.equals(expectedLevel)) {
|
|
throw new RuntimeException("Unexpected level: " + level);
|
|
}
|
|
|
|
ss = source.split("\\s+");
|
|
int len = ss.length;
|
|
if (!(len == 2 &&
|
|
ss[0].equals("SimpleFormatterFormat") &&
|
|
ss[1].equals("writeLogRecords"))) {
|
|
throw new RuntimeException("Unexpected source: " + source);
|
|
}
|
|
}
|
|
}
|