8270025: DynamicCallSiteDesc::withArgs doesn't throw NPE

Reviewed-by: jvernee, mchung
This commit is contained in:
Vicente Romero 2021-07-13 17:48:21 +00:00
parent d32e42cdd4
commit 8583aab374
2 changed files with 197 additions and 2 deletions
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

@ -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()));
}
}