8270025: DynamicCallSiteDesc::withArgs doesn't throw NPE
Reviewed-by: jvernee, mchung
This commit is contained in:
parent
d32e42cdd4
commit
8583aab374
src/java.base/share/classes/java/lang/constant
test/jdk/java/lang/constant
@ -66,7 +66,7 @@ public class DynamicCallSiteDesc {
|
||||
* @param bootstrapArgs {@link ConstantDesc}s describing the static arguments
|
||||
* to the bootstrap, that would appear in the
|
||||
* {@code BootstrapMethods} attribute
|
||||
* @throws NullPointerException if any parameter is null
|
||||
* @throws NullPointerException if any parameter or its contents are {@code null}
|
||||
* @throws IllegalArgumentException if the invocation name has the incorrect
|
||||
* format
|
||||
* @jvms 4.2.2 Unqualified Names
|
||||
@ -79,6 +79,9 @@ public class DynamicCallSiteDesc {
|
||||
this.invocationType = requireNonNull(invocationType);
|
||||
this.bootstrapMethod = requireNonNull(bootstrapMethod);
|
||||
this.bootstrapArgs = requireNonNull(bootstrapArgs.clone());
|
||||
for (int i = 0; i < this.bootstrapArgs.length; i++) {
|
||||
requireNonNull(this.bootstrapArgs[i]);
|
||||
}
|
||||
if (invocationName.length() == 0)
|
||||
throw new IllegalArgumentException("Illegal invocation name: " + invocationName);
|
||||
}
|
||||
@ -97,7 +100,7 @@ public class DynamicCallSiteDesc {
|
||||
* to the bootstrap, that would appear in the
|
||||
* {@code BootstrapMethods} attribute
|
||||
* @return the nominal descriptor
|
||||
* @throws NullPointerException if any parameter is null
|
||||
* @throws NullPointerException if any parameter or its contents are {@code null}
|
||||
* @throws IllegalArgumentException if the invocation name has the incorrect
|
||||
* format
|
||||
* @jvms 4.2.2 Unqualified Names
|
||||
|
192
test/jdk/java/lang/constant/DynamicCallSiteDescTest.java
Normal file
192
test/jdk/java/lang/constant/DynamicCallSiteDescTest.java
Normal file
@ -0,0 +1,192 @@
|
||||
/*
|
||||
* Copyright (c) 2021, 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.
|
||||
*/
|
||||
|
||||
import java.lang.invoke.MethodType;
|
||||
import java.lang.constant.*;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.stream.IntStream;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import org.testng.annotations.Test;
|
||||
|
||||
import static java.lang.constant.ConstantDescs.CD_int;
|
||||
import static java.lang.constant.ConstantDescs.CD_void;
|
||||
import static java.util.stream.Collectors.joining;
|
||||
import static java.util.stream.Collectors.toList;
|
||||
import static org.testng.Assert.assertEquals;
|
||||
import static org.testng.Assert.fail;
|
||||
|
||||
/**
|
||||
* @test
|
||||
* @compile DynamicCallSiteDescTest.java
|
||||
* @run testng DynamicCallSiteDescTest
|
||||
* @summary unit tests for java.lang.constant.DynamicCallSiteDesc
|
||||
*/
|
||||
|
||||
@Test
|
||||
public class DynamicCallSiteDescTest extends SymbolicDescTest {
|
||||
/* note there is no unit test for method resolveCallSiteDesc as it is being tested in another test in this
|
||||
* suite, IndyDescTest
|
||||
*/
|
||||
|
||||
public void testOf() throws ReflectiveOperationException {
|
||||
DirectMethodHandleDesc dmh = ConstantDescs.ofCallsiteBootstrap(
|
||||
ClassDesc.of("BootstrapAndTarget"),
|
||||
"bootstrap",
|
||||
ClassDesc.of("java.lang.invoke.CallSite")
|
||||
);
|
||||
try {
|
||||
DynamicCallSiteDesc.of(
|
||||
dmh,
|
||||
"",
|
||||
MethodTypeDesc.ofDescriptor("()I")
|
||||
);
|
||||
fail("IllegalArgumentException expected");
|
||||
} catch (IllegalArgumentException iae) {
|
||||
// good
|
||||
}
|
||||
|
||||
try {
|
||||
DynamicCallSiteDesc.of(
|
||||
null,
|
||||
"getTarget",
|
||||
MethodTypeDesc.ofDescriptor("()I")
|
||||
);
|
||||
fail("NullPointerException expected");
|
||||
} catch (NullPointerException npe) {
|
||||
// good
|
||||
}
|
||||
|
||||
try {
|
||||
DynamicCallSiteDesc.of(
|
||||
dmh,
|
||||
null,
|
||||
MethodTypeDesc.ofDescriptor("()I")
|
||||
);
|
||||
fail("NullPointerException expected");
|
||||
} catch (NullPointerException npe) {
|
||||
// good
|
||||
}
|
||||
|
||||
try {
|
||||
DynamicCallSiteDesc.of(
|
||||
dmh,
|
||||
"getTarget",
|
||||
null
|
||||
);
|
||||
fail("NullPointerException expected");
|
||||
} catch (NullPointerException npe) {
|
||||
// good
|
||||
}
|
||||
|
||||
try {
|
||||
DynamicCallSiteDesc.of(
|
||||
dmh,
|
||||
"getTarget",
|
||||
MethodTypeDesc.ofDescriptor("()I"),
|
||||
null
|
||||
);
|
||||
fail("NullPointerException expected");
|
||||
} catch (NullPointerException npe) {
|
||||
// good
|
||||
}
|
||||
try {
|
||||
DynamicCallSiteDesc.of(
|
||||
dmh,
|
||||
"getTarget",
|
||||
MethodTypeDesc.ofDescriptor("()I"),
|
||||
new ConstantDesc[]{ null }
|
||||
);
|
||||
fail("NullPointerException expected");
|
||||
} catch (NullPointerException npe) {
|
||||
// good
|
||||
}
|
||||
}
|
||||
|
||||
public void testWithArgs() throws ReflectiveOperationException {
|
||||
DynamicCallSiteDesc desc = DynamicCallSiteDesc.of(ConstantDescs.ofCallsiteBootstrap(
|
||||
ClassDesc.of("BootstrapAndTarget"),
|
||||
"bootstrap",
|
||||
ClassDesc.of("java.lang.invoke.CallSite")
|
||||
),
|
||||
"getTarget",
|
||||
MethodTypeDesc.ofDescriptor("()I")
|
||||
);
|
||||
|
||||
try {
|
||||
desc.withArgs(null);
|
||||
fail("NullPointerException expected");
|
||||
} catch (NullPointerException npe) {
|
||||
// good
|
||||
}
|
||||
|
||||
try {
|
||||
desc.withArgs(new ConstantDesc[]{ null });
|
||||
fail("NullPointerException expected");
|
||||
} catch (NullPointerException npe) {
|
||||
// good
|
||||
}
|
||||
}
|
||||
|
||||
public void testWithNameAndType() throws ReflectiveOperationException {
|
||||
DynamicCallSiteDesc desc = DynamicCallSiteDesc.of(ConstantDescs.ofCallsiteBootstrap(
|
||||
ClassDesc.of("BootstrapAndTarget"),
|
||||
"bootstrap",
|
||||
ClassDesc.of("java.lang.invoke.CallSite")
|
||||
),
|
||||
"getTarget",
|
||||
MethodTypeDesc.ofDescriptor("()I")
|
||||
);
|
||||
|
||||
try {
|
||||
desc.withNameAndType(null, MethodTypeDesc.ofDescriptor("()I"));
|
||||
fail("NullPointerException expected");
|
||||
} catch (NullPointerException npe) {
|
||||
// good
|
||||
}
|
||||
|
||||
try {
|
||||
desc.withNameAndType("bootstrap", null);
|
||||
fail("NullPointerException expected");
|
||||
} catch (NullPointerException npe) {
|
||||
// good
|
||||
}
|
||||
}
|
||||
|
||||
public void testAccessorsAndFactories() throws ReflectiveOperationException {
|
||||
DynamicCallSiteDesc desc = DynamicCallSiteDesc.of(ConstantDescs.ofCallsiteBootstrap(
|
||||
ClassDesc.of("BootstrapAndTarget"),
|
||||
"bootstrap",
|
||||
ClassDesc.of("java.lang.invoke.CallSite")
|
||||
),
|
||||
"_",
|
||||
MethodTypeDesc.ofDescriptor("()I")
|
||||
);
|
||||
assertEquals(desc, DynamicCallSiteDesc.of((DirectMethodHandleDesc)desc.bootstrapMethod(), desc.invocationType()));
|
||||
assertEquals(desc, DynamicCallSiteDesc.of((DirectMethodHandleDesc)desc.bootstrapMethod(),
|
||||
desc.invocationName(), desc.invocationType()));
|
||||
assertEquals(desc, DynamicCallSiteDesc.of((DirectMethodHandleDesc)desc.bootstrapMethod(),
|
||||
desc.invocationName(), desc.invocationType(), desc.bootstrapArgs()));
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user