LogGeneratedClassesTest.java revision 8383:94d4aa2fb414
1/*
2 * Copyright (c) 2013, 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
26 * @bug 8023524
27 * @summary tests logging generated classes for lambda
28 * @library /java/nio/file
29 * @run testng LogGeneratedClassesTest
30 */
31import java.io.File;
32import java.io.IOException;
33import java.util.ArrayList;
34import java.util.List;
35import java.nio.file.Files;
36import java.nio.file.LinkOption;
37import java.nio.file.Path;
38import java.nio.file.Paths;
39import java.nio.file.attribute.PosixFileAttributeView;
40import java.util.stream.Stream;
41
42import org.testng.annotations.AfterClass;
43import org.testng.annotations.BeforeClass;
44import org.testng.annotations.Test;
45import org.testng.SkipException;
46
47import static java.nio.file.attribute.PosixFilePermissions.*;
48import static org.testng.Assert.assertEquals;
49import static org.testng.Assert.assertFalse;
50import static org.testng.Assert.assertTrue;
51
52public class LogGeneratedClassesTest extends LUtils {
53    String longFQCN;
54
55    @BeforeClass
56    public void setup() throws IOException {
57        final List<String> scratch = new ArrayList<>();
58        scratch.clear();
59        scratch.add("package com.example;");
60        scratch.add("public class TestLambda {");
61        scratch.add("    interface I {");
62        scratch.add("        int foo();");
63        scratch.add("    }");
64        scratch.add("    public static void main(String[] args) {");
65        scratch.add("        I lam = () -> 10;");
66        scratch.add("        Runnable r = () -> {");
67        scratch.add("            System.out.println(\"Runnable\");");
68        scratch.add("        };");
69        scratch.add("        r.run();");
70        scratch.add("        System.out.println(\"Finish\");");
71        scratch.add("    }");
72        scratch.add("}");
73
74        File test = new File("TestLambda.java");
75        createFile(test, scratch);
76        compile("-d", ".", test.getName());
77
78        scratch.remove(0);
79        scratch.remove(0);
80        scratch.add(0, "public class LongPackageName {");
81        StringBuilder sb = new StringBuilder("com.example.");
82        // longer than 255 which exceed max length of most filesystems
83        for (int i = 0; i < 30; i++) {
84            sb.append("nonsense.");
85        }
86        sb.append("enough");
87        longFQCN = sb.toString() + ".LongPackageName";
88        sb.append(";");
89        sb.insert(0, "package ");
90        scratch.add(0, sb.toString());
91        test = new File("LongPackageName.java");
92        createFile(test, scratch);
93        compile("-d", ".", test.getName());
94
95        // create target
96        Files.createDirectory(Paths.get("dump"));
97        Files.createDirectories(Paths.get("dumpLong/com/example/nonsense"));
98        Files.createFile(Paths.get("dumpLong/com/example/nonsense/nonsense"));
99        Files.createFile(Paths.get("file"));
100    }
101
102    @AfterClass
103    public void cleanup() throws IOException {
104        Files.delete(Paths.get("TestLambda.java"));
105        Files.delete(Paths.get("LongPackageName.java"));
106        Files.delete(Paths.get("file"));
107        TestUtil.removeAll(Paths.get("com"));
108        TestUtil.removeAll(Paths.get("dump"));
109        TestUtil.removeAll(Paths.get("dumpLong"));
110    }
111
112    @Test
113    public void testNotLogging() {
114        TestResult tr = doExec(JAVA_CMD.getAbsolutePath(),
115                               "-cp", ".",
116                               "-Djava.security.manager",
117                               "com.example.TestLambda");
118        tr.assertZero("Should still return 0");
119    }
120
121    @Test
122    public void testLogging() throws IOException {
123        assertTrue(Files.exists(Paths.get("dump")));
124        TestResult tr = doExec(JAVA_CMD.getAbsolutePath(),
125                               "-cp", ".",
126                               "-Djdk.internal.lambda.dumpProxyClasses=dump",
127                               "-Djava.security.manager",
128                               "com.example.TestLambda");
129        // dump/com/example + 2 class files
130        assertEquals(Files.walk(Paths.get("dump")).count(), 5, "Two lambda captured");
131        tr.assertZero("Should still return 0");
132    }
133
134    @Test
135    public void testDumpDirNotExist() throws IOException {
136        assertFalse(Files.exists(Paths.get("notExist")));
137        TestResult tr = doExec(JAVA_CMD.getAbsolutePath(),
138                               "-cp", ".",
139                               "-Djdk.internal.lambda.dumpProxyClasses=notExist",
140                               "-Djava.security.manager",
141                               "com.example.TestLambda");
142        assertEquals(tr.testOutput.stream()
143                                  .filter(s -> s.startsWith("WARNING"))
144                                  .peek(s -> assertTrue(s.contains("does not exist")))
145                                  .count(),
146                     1, "only show error once");
147        tr.assertZero("Should still return 0");
148    }
149
150    @Test
151    public void testDumpDirIsFile() throws IOException {
152        assertTrue(Files.isRegularFile(Paths.get("file")));
153        TestResult tr = doExec(JAVA_CMD.getAbsolutePath(),
154                               "-cp", ".",
155                               "-Djdk.internal.lambda.dumpProxyClasses=file",
156                               "-Djava.security.manager",
157                               "com.example.TestLambda");
158        assertEquals(tr.testOutput.stream()
159                                  .filter(s -> s.startsWith("WARNING"))
160                                  .peek(s -> assertTrue(s.contains("not a directory")))
161                                  .count(),
162                     1, "only show error once");
163        tr.assertZero("Should still return 0");
164    }
165
166    @Test
167    public void testDumpDirNotWritable() throws IOException {
168        if (! Files.getFileStore(Paths.get("."))
169                   .supportsFileAttributeView(PosixFileAttributeView.class)) {
170            // No easy way to setup readonly directory without POSIX
171            // We would like to skip the test with a cause with
172            //     throw new SkipException("Posix not supported");
173            // but jtreg will report failure so we just pass the test
174            // which we can look at if jtreg changed its behavior
175            return;
176        }
177
178        Files.createDirectory(Paths.get("readOnly"),
179                              asFileAttribute(fromString("r-xr-xr-x")));
180
181        TestResult tr = doExec(JAVA_CMD.getAbsolutePath(),
182                               "-cp", ".",
183                               "-Djdk.internal.lambda.dumpProxyClasses=readOnly",
184                               "-Djava.security.manager",
185                               "com.example.TestLambda");
186        assertEquals(tr.testOutput.stream()
187                                  .filter(s -> s.startsWith("WARNING"))
188                                  .peek(s -> assertTrue(s.contains("not writable")))
189                                  .count(),
190                     1, "only show error once");
191        tr.assertZero("Should still return 0");
192
193        TestUtil.removeAll(Paths.get("readOnly"));
194    }
195
196    @Test
197    public void testLoggingException() throws IOException {
198        assertTrue(Files.exists(Paths.get("dumpLong")));
199        TestResult tr = doExec(JAVA_CMD.getAbsolutePath(),
200                               "-cp", ".",
201                               "-Djdk.internal.lambda.dumpProxyClasses=dumpLong",
202                               "-Djava.security.manager",
203                               longFQCN);
204        assertEquals(tr.testOutput.stream()
205                                  .filter(s -> s.startsWith("WARNING: Exception"))
206                                  .count(),
207                     2, "show error each capture");
208        // dumpLong/com/example/nosense/nosense
209        assertEquals(Files.walk(Paths.get("dumpLong")).count(), 5, "Two lambda captured failed to log");
210        tr.assertZero("Should still return 0");
211    }
212}
213