Path: blob/master/test/hotspot/jtreg/compiler/jvmci/compilerToVM/GetImplementorTest.java
41153 views
/*1* Copyright (c) 2015, 2019, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/*24* @test25* @bug 813642126* @requires vm.jvmci27* @library / /test/lib/28* @library ../common/patches29* @modules java.base/jdk.internal.misc30* @modules jdk.internal.vm.ci/jdk.vm.ci.hotspot31* @build jdk.internal.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper32* @run main/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI33* -XX:-UseJVMCICompiler34* compiler.jvmci.compilerToVM.GetImplementorTest35*/3637package compiler.jvmci.compilerToVM;3839import compiler.jvmci.common.testcases.AbstractClass;40import compiler.jvmci.common.testcases.AbstractClassExtender;41import compiler.jvmci.common.testcases.DoNotExtendClass;42import compiler.jvmci.common.testcases.DoNotImplementInterface;43import compiler.jvmci.common.testcases.MultipleImplementer1;44import compiler.jvmci.common.testcases.MultipleImplementer2;45import compiler.jvmci.common.testcases.MultipleImplementersInterface;46import compiler.jvmci.common.testcases.SingleImplementer;47import compiler.jvmci.common.testcases.SingleImplementerInterface;48import compiler.jvmci.common.testcases.SingleSubclass;49import compiler.jvmci.common.testcases.SingleSubclassedClass;50import jdk.test.lib.Asserts;51import jdk.test.lib.Utils;52import jdk.vm.ci.hotspot.CompilerToVMHelper;53import jdk.vm.ci.hotspot.HotSpotResolvedObjectType;5455import java.util.HashSet;56import java.util.Set;57import java.util.stream.Stream;5859public class GetImplementorTest {60public static void main(String args[]) {61GetImplementorTest test = new GetImplementorTest();62for (TestCase tcase : createTestCases()) {63test.runTest(tcase);64}65}6667private static Set<TestCase> createTestCases() {68Set<TestCase> result = new HashSet<>();69Stream.of(70SingleSubclass.class,71AbstractClassExtender.class,72MultipleImplementer2.class,73MultipleImplementer1.class,74MultipleImplementersInterface.class,75DoNotImplementInterface.class,76DoNotExtendClass.class,77AbstractClass.class,78SingleSubclassedClass.class)79.forEach(Utils::ensureClassIsLoaded);80// an interface with single class implementing it81result.add(new TestCase(SingleImplementerInterface.class,82SingleImplementer.class));83/* an interface with multiple implementers. According to getImplementor84javadoc, an itself should be returned in case of more than one85implementor86*/87result.add(new TestCase(MultipleImplementersInterface.class,88MultipleImplementersInterface.class));89// an interface with no implementors90result.add(new TestCase(DoNotImplementInterface.class, null));91// an abstract class with extender class92result.add(new TestCase(AbstractClass.class, null));93// a simple class, which is not extended94result.add(new TestCase(DoNotExtendClass.class, null));95// a usual class, which is extended96result.add(new TestCase(SingleSubclassedClass.class, null));97return result;98}99100private void runTest(TestCase tcase) {101System.out.println(tcase);102HotSpotResolvedObjectType resolvedIface = CompilerToVMHelper103.lookupTypeHelper(Utils.toJVMTypeSignature(tcase.anInterface),104getClass(), /* resolve = */ true);105if (!resolvedIface.isInterface()) {106try {107CompilerToVMHelper.getImplementor(resolvedIface);108Asserts.fail("Expected " + IllegalArgumentException.class.getName());109} catch (IllegalArgumentException e) {110}111return;112}113HotSpotResolvedObjectType resolvedImplementer = CompilerToVMHelper114.getImplementor(resolvedIface);115HotSpotResolvedObjectType resolvedExpected = null;116if (tcase.expectedImplementer != null) {117resolvedExpected = CompilerToVMHelper.lookupTypeHelper(Utils118.toJVMTypeSignature(tcase.expectedImplementer),119getClass(), /* resolve = */ true);120}121Asserts.assertEQ(resolvedImplementer, resolvedExpected,122"Unexpected implementer for " + tcase.anInterface.getName());123}124125private static class TestCase {126public final Class<?> anInterface;127public final Class<?> expectedImplementer;128129public TestCase(Class<?> iface, Class<?> expectedImplementer) {130this.anInterface = iface;131this.expectedImplementer = expectedImplementer;132}133134@Override135public String toString() {136return String.format("CASE: interface=%s, expected=%s",137anInterface.getName(),138expectedImplementer == null139? null140: expectedImplementer.getName());141}142}143}144145146