| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package org.apache.harmony.jpda.tests.jdwp.ObjectReference; |
| |
| import org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer; |
| import org.apache.harmony.jpda.tests.share.SyncDebuggee; |
| |
| public class InvokeMethodDefaultDebuggee extends SyncDebuggee { |
| |
| /** |
| * Interface defining the default method to be invoked. |
| */ |
| public static interface TestInterface { |
| public static final int RETURN_VALUE = 123; |
| /** |
| * Method invoked for test |
| * @param shouldThrow throws if the value is true. |
| * @return the value 123 |
| */ |
| public default int testDefaultMethod(boolean shouldThrow) throws Throwable { |
| if (shouldThrow) { |
| throw new Throwable("testDefaultMethod"); |
| } |
| return TestInterface.RETURN_VALUE; |
| } |
| } |
| |
| /** |
| * The empty class we will initialize to call the default method. |
| */ |
| public static class TestClass implements TestInterface { |
| } |
| |
| // The instance used to invoke "TestClass.testMethod". |
| static TestClass invokeReceiver = new TestClass(); |
| |
| void execMethod() { |
| logWriter.println("InvokeMethodDefaultDebuggee.execMethod()"); |
| } |
| |
| @Override |
| public void run() { |
| // Preload TestClass so it is available during the test. |
| @SuppressWarnings("unused") |
| Class<?> c = null; |
| String packageName = "org.apache.harmony.jpda.tests.jdwp."; |
| try { |
| c = Class.forName( |
| packageName + "ObjectReference.InvokeMethodDefaultDebuggee$TestClass"); |
| } catch (ClassNotFoundException e) { |
| e.printStackTrace(); |
| } |
| synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_READY); |
| logWriter.println("InvokeMethodDefaultDebuggee"); |
| synchronizer.receiveMessageWithoutException( |
| packageName + "ObjectReference.InvokeMethodDefaultDebuggee(#1)"); |
| execMethod(); |
| synchronizer.receiveMessageWithoutException( |
| packageName + "ObjectReference.InvokeMethodDefaultDebuggee(#2)"); |
| } |
| |
| public static void main(String[] args) { |
| runDebuggee(InvokeMethodDefaultDebuggee.class); |
| } |
| } |
| |