Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/langtools/jdk/javadoc/tool/modules/PatchModules.java
40974 views
1
/*
2
* Copyright (c) 2017, 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 8175346
27
* @summary Test patch module options
28
* @modules
29
* jdk.javadoc/jdk.javadoc.internal.api
30
* jdk.javadoc/jdk.javadoc.internal.tool
31
* jdk.compiler/com.sun.tools.javac.api
32
* jdk.compiler/com.sun.tools.javac.main
33
* @library /tools/lib
34
* @build toolbox.ToolBox toolbox.TestRunner
35
* @run main PatchModules
36
*/
37
38
import java.nio.file.Path;
39
import java.nio.file.Paths;
40
41
import toolbox.*;
42
43
public class PatchModules extends ModuleTestBase {
44
45
public static void main(String... args) throws Exception {
46
new PatchModules().runTests();
47
}
48
49
// Case A.1, m2 augmenting m1
50
@Test
51
public void testPatchModuleOption(Path base) throws Exception {
52
Path src = base.resolve("src");
53
Path modulePath = base.resolve("modules");
54
Path patchPath = base.resolve("patch");
55
56
ModuleBuilder mb1 = new ModuleBuilder(tb, "m1");
57
mb1.comment("Module on module path.")
58
.exports("pkg1")
59
.classes("package pkg1; /** Class A */ public class A { }")
60
.build(modulePath);
61
62
tb.writeJavaFiles(patchPath, "package pkg1; /** Class A */ public class A { public static int k; }");
63
new JavacTask(tb)
64
.files(patchPath.resolve("pkg1/A.java"))
65
.run();
66
67
ModuleBuilder mb2 = new ModuleBuilder(tb, "m2");
68
mb2.comment("The second module.")
69
.exports("pkg2")
70
.requires("m1")
71
.classes("package pkg2; /** Class B */ public class B { /** Field f */ public int f = pkg1.A.k; }")
72
.write(src);
73
execTask("--module-source-path", src.toString(),
74
"--patch-module", "m1=" + patchPath.toString(),
75
"--module-path", modulePath.toString(),
76
"--module", "m2");
77
checkModulesSpecified("m2");
78
checkPackagesIncluded("pkg2");
79
checkMembersSelected("pkg2.B.f");
80
}
81
82
// Case A.2: use package, source form of m1 augmenting binary form of m1
83
@Test
84
public void testPatchModuleWithPackage(Path base) throws Exception {
85
Path modulePath = base.resolve("modules");
86
Path moduleSrcPath = base.resolve("modulesSrc");
87
88
Path mpath = Paths.get(moduleSrcPath.toString(), "m1");
89
90
ModuleBuilder mb1 = new ModuleBuilder(tb, "m1");
91
mb1.comment("Module m1.")
92
.exports("pkg1")
93
.classes("package pkg1; /** Class A */ public class A { }")
94
.classes("package pkg1.pkg2; /** Class B */ public class B { }")
95
.build(modulePath);
96
97
execTask("-hasDocComments",
98
"--module-path", modulePath.toString(),
99
"--add-modules", "m1",
100
"--patch-module", "m1=" + mpath.toString(),
101
"pkg1");
102
checkTypesIncluded("pkg1.A hasDocComments");
103
}
104
105
// Case A.2: use subpackages, source form of m1 augmenting binary form of m1
106
@Test
107
public void testPatchModuleWithSubPackages(Path base) throws Exception {
108
Path modulePath = base.resolve("modules");
109
Path moduleSrcPath = base.resolve("modulesSrc");
110
111
Path mpath = Paths.get(moduleSrcPath.toString(), "m1");
112
113
ModuleBuilder mb1 = new ModuleBuilder(tb, "m1");
114
mb1.comment("Module m1.")
115
.exports("pkg1")
116
.classes("package pkg1; /** Class A */ public class A { }")
117
.classes("package pkg1.pkg2; /** Class B */ public class B { }")
118
.build(modulePath);
119
120
execTask("-hasDocComments",
121
"--module-path", modulePath.toString(),
122
"--add-modules", "m1",
123
"--patch-module", "m1=" + mpath.toString(),
124
"-subpackages", "pkg1");
125
checkTypesIncluded("pkg1.A hasDocComments");
126
checkTypesIncluded("pkg1.pkg2.B hasDocComments");
127
}
128
129
// Case B.1: (jsr166) augment and override system module
130
@Test
131
public void testPatchModuleModifyingSystemModule(Path base) throws Exception {
132
Path patchSrc = base.resolve("patch");
133
134
// build the patching sources
135
tb.writeJavaFiles(patchSrc, """
136
package java.util;
137
/** Class Collection */
138
public interface Collection<K> {}""");
139
140
tb.writeJavaFiles(patchSrc, """
141
package java.util;
142
/** Class MyCollection */
143
public interface MyCollection<K> extends Collection {}""");
144
145
execTask("-hasDocComments", "--patch-module", "java.base=" + patchSrc.toString(),
146
"java.util");
147
148
checkPackagesSpecified("java.util");
149
checkTypesIncluded("java.util.Collection hasDocComments",
150
"java.util.MyCollection hasDocComments");
151
}
152
153
// Case C.1: patch a user module's sources using source path
154
@Test
155
public void testPatchModuleUsingSourcePath(Path base) throws Exception {
156
Path src = base.resolve("src");
157
Path patchSrc = base.resolve("patch");
158
159
ModuleBuilder mb1 = new ModuleBuilder(tb, "m1");
160
mb1.comment("Module m1.")
161
.exports("pkg1")
162
.classes("package pkg1; /** Class A */ public class A { }")
163
.write(src);
164
165
// build the patching module
166
tb.writeJavaFiles(patchSrc, """
167
package pkg1;
168
/** Class A */ public class A extends java.util.ArrayList { }""");
169
tb.writeJavaFiles(patchSrc, """
170
package pkg1;
171
/** Class B */ public class B { }""");
172
173
Path m1src = Paths.get(src.toString(), "m1");
174
175
execTask("--source-path", m1src.toString(),
176
"--patch-module", "m1=" + patchSrc.toString(),
177
"pkg1");
178
179
checkPackagesSpecified("pkg1");
180
checkModulesIncluded("m1");
181
checkTypesIncluded("pkg1.A", "pkg1.B");
182
}
183
184
// Case C.2: patch a user module's sources using module source path
185
@Test
186
public void testPatchModuleWithModuleSourcePath(Path base) throws Exception {
187
Path src = base.resolve("src");
188
Path patchSrc = base.resolve("patch");
189
190
ModuleBuilder mb1 = new ModuleBuilder(tb, "m1");
191
mb1.comment("Module on module-source-path.")
192
.exports("pkg1")
193
.classes("package pkg1; /** Class A */ public class A { }")
194
.write(src);
195
196
// build the patching module
197
tb.writeJavaFiles(patchSrc, """
198
package pkg1;
199
/** Class A */ public class A extends java.util.ArrayList { }""");
200
tb.writeJavaFiles(patchSrc, """
201
package pkg1;
202
/** Class B */ public class B { }""");
203
204
205
execTask("--module-source-path", src.toString(),
206
"--add-modules", "m1",
207
"--patch-module", "m1=" + patchSrc.toString(),
208
"pkg1");
209
210
checkPackagesSpecified("pkg1");
211
checkModulesIncluded("m1");
212
checkTypesIncluded("pkg1.A", "pkg1.B");
213
}
214
215
}
216
217