Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/hotspot/jtreg/serviceability/logging/TestLogRotation.java
41152 views
1
/*
2
* Copyright (c) 2012, 2020, Oracle and/or its affiliates. All rights reserved.
3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
*
5
* This code is free software; you can redistribute it and/or modify it
6
* under the terms of the GNU General Public License version 2 only, as
7
* published by the Free Software Foundation.
8
*
9
* This code is distributed in the hope that it will be useful, but WITHOUT
10
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12
* version 2 for more details (a copy is included in the LICENSE file that
13
* accompanied this code).
14
*
15
* You should have received a copy of the GNU General Public License version
16
* 2 along with this work; if not, write to the Free Software Foundation,
17
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18
*
19
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20
* or visit www.oracle.com if you need additional information or have any
21
* questions.
22
*/
23
24
/*
25
* @test TestLogRotation.java
26
* @summary test flags for log rotation
27
* @library /test/lib
28
* @modules java.base/jdk.internal.misc
29
* java.management
30
* @run driver/timeout=600 TestLogRotation
31
*
32
*/
33
import jdk.test.lib.process.ProcessTools;
34
import java.io.File;
35
import java.io.FilenameFilter;
36
import java.util.ArrayList;
37
import java.util.Arrays;
38
39
class GCLoggingGenerator {
40
41
public static void main(String[] args) throws Exception {
42
43
long sizeOfLog = Long.parseLong(args[0]);
44
long lines = sizeOfLog / 70;
45
// full.GC generates ad least 1-line which is not shorter then 70 chars
46
// for some GC 2 shorter lines are generated
47
for (long i = 0; i < lines; i++) {
48
System.gc();
49
}
50
}
51
}
52
53
public class TestLogRotation {
54
55
static final File currentDirectory = new File(".");
56
static final String logFileName = "test.log";
57
static final int logFileSizeK = 16;
58
static FilenameFilter logFilter = new FilenameFilter() {
59
@Override
60
public boolean accept(File dir, String name) {
61
return name.startsWith(logFileName);
62
}
63
};
64
65
public static void cleanLogs() {
66
for (File log : currentDirectory.listFiles(logFilter)) {
67
if (!log.delete()) {
68
throw new Error("Unable to delete " + log.getAbsolutePath());
69
}
70
}
71
}
72
73
public static void runTest(int numberOfFiles) throws Exception {
74
ProcessBuilder pb = ProcessTools.createTestJvm(
75
"-cp", System.getProperty("java.class.path"),
76
"-Xlog:gc=debug:" + logFileName
77
+ "::filesize=" + logFileSizeK + "k"
78
+ ",filecount=" + numberOfFiles,
79
"-XX:-DisableExplicitGC", // to ensure that System.gc() works
80
"-Xmx128M",
81
GCLoggingGenerator.class.getName(),
82
String.valueOf(numberOfFiles * logFileSizeK * 1024));
83
pb.redirectErrorStream(true);
84
pb.redirectOutput(new File(GCLoggingGenerator.class.getName() + ".log"));
85
Process process = pb.start();
86
int result = process.waitFor();
87
if (result != 0) {
88
throw new Error("Unexpected exit code = " + result);
89
}
90
File[] logs = currentDirectory.listFiles(logFilter);
91
int smallFilesNumber = 0;
92
for (File log : logs) {
93
if (log.length() < logFileSizeK * 1024) {
94
smallFilesNumber++;
95
}
96
}
97
// Expect one more log file since the number-of-files doesn't include the active log file
98
int expectedNumberOfFiles = numberOfFiles + 1;
99
if (logs.length != expectedNumberOfFiles) {
100
throw new Error("There are " + logs.length + " logs instead of the expected " + expectedNumberOfFiles);
101
}
102
if (smallFilesNumber > 1) {
103
throw new Error("There should maximum one log with size < " + logFileSizeK + "K");
104
}
105
}
106
107
public static void main(String[] args) throws Exception {
108
cleanLogs();
109
runTest(1);
110
cleanLogs();
111
runTest(3);
112
cleanLogs();
113
}
114
}
115
116