/* * Copyright (c) 2016, 2022, 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. */ #include "precompiled.hpp" #include "classfile/symbolTable.hpp" #include "classfile/systemDictionary.hpp" #include "classfile/vmClasses.hpp" #include "classfile/vmSymbols.hpp" #include "memory/resourceArea.hpp" #include "oops/instanceKlass.hpp" #include "oops/klass.inline.hpp" #include "oops/method.hpp" #include "runtime/interfaceSupport.inline.hpp" #include "unittest.hpp" // Tests for InstanceKlass::is_class_loader_instance_klass() function TEST_VM(InstanceKlass, class_loader_class) { InstanceKlass* klass = vmClasses::ClassLoader_klass(); ASSERT_TRUE(klass->is_class_loader_instance_klass()); } TEST_VM(InstanceKlass, string_klass) { InstanceKlass* klass = vmClasses::String_klass(); ASSERT_TRUE(!klass->is_class_loader_instance_klass()); } TEST_VM(InstanceKlass, class_loader_printer) { ThreadInVMfromNative scope(JavaThread::current()); ResourceMark rm; oop loader = SystemDictionary::java_platform_loader(); stringStream st; loader->print_on(&st); // See if injected loader_data field is printed in string ASSERT_TRUE(strstr(st.as_string(), "internal 'loader_data'") != NULL) << "Must contain internal fields"; st.reset(); // See if mirror injected fields are printed. oop mirror = vmClasses::ClassLoader_klass()->java_mirror(); mirror->print_on(&st); ASSERT_TRUE(strstr(st.as_string(), "internal 'protection_domain'") != NULL) << "Must contain internal fields"; // We should test other printing functions too. #ifndef PRODUCT st.reset(); // method printing is non-product Method* method = vmClasses::ClassLoader_klass()->methods()->at(0); // we know there's a method here! method->print_on(&st); ASSERT_TRUE(strstr(st.as_string(), "method holder:") != NULL) << "Must contain method_holder field"; ASSERT_TRUE(strstr(st.as_string(), "'java/lang/ClassLoader'") != NULL) << "Must be in ClassLoader"; #endif } #ifndef PRODUCT // This class is friends with Method. class MethodTest : public ::testing::Test{ public: static void compare_names(Method* method, Symbol* name) { ASSERT_EQ(method->_name, name) << "Method name field isn't set"; } }; TEST_VM(Method, method_name) { InstanceKlass* ik = vmClasses::Object_klass(); Symbol* tostring = SymbolTable::new_symbol("toString"); Method* method = ik->find_method(tostring, vmSymbols::void_string_signature()); ASSERT_TRUE(method != nullptr) << "Object must have toString"; MethodTest::compare_names(method, tostring); } #endif