MethodEntryExitEvents.java revision 2362
2362N/A * Copyright (c) 2001, 2007, Oracle and/or its affiliates. All rights reserved. 0N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 0N/A * This code is free software; you can redistribute it and/or modify it 0N/A * under the terms of the GNU General Public License version 2 only, as 0N/A * published by the Free Software Foundation. 0N/A * This code is distributed in the hope that it will be useful, but WITHOUT 0N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 0N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 0N/A * version 2 for more details (a copy is included in the LICENSE file that 0N/A * accompanied this code). 0N/A * You should have received a copy of the GNU General Public License version 0N/A * 2 along with this work; if not, write to the Free Software Foundation, 0N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 2362N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 2362N/A * or visit www.oracle.com if you need additional information or have any 0N/A * @bug 4409241 4432820 2546N/A * @summary Test the bug fix for: MethodExitEvents disappear when Object-Methods are called from main 0N/A * @run build TestScaffold VMConnection TargetListener TargetAdapter 0N/A * @run main MethodEntryExitEvents SUSPEND_EVENT_THREAD MethodEntryExitEventsDebugee 0N/A * @run main MethodEntryExitEvents SUSPEND_NONE MethodEntryExitEventsDebugee 0N/A * @run main MethodEntryExitEvents SUSPEND_ALL MethodEntryExitEventsDebugee * The implementation here is deliberately inefficient * because the debugger is still watching this method. sb.
append (
"MethodEntryExitEventsDebugee: ");
sb.
append (
"Executing loopComplete method for a graceful shutdown...");
for (
int i =
0; i < s.
length(); i++) {
for (
int j =
0; j <
3; j++) {
* Enter main() , then t2.<init>, then sayHello[1,2,3,4,5] 15 times 3 loops, * Exit t2.<init>, then sayHello[1,2,3,4,5] 15 times 3 loopa * (event monitoring is cancelled before we exit loopComplete() or main()) * Class patterns for which we don't want events (copied sb.
append(
" [SUSPEND_NONE | SUSPEND_EVENT_THREAD | SUSPEND_ALL]");
sb.
append(
" [MethodEntryExitEventsDebugee | -connect <connector options...>] ");
// disable the step and then run to completion //eventRequestManager().deleteEventRequest(event.request()); // We have to count the entry to loopComplete, but //Pick up the SUSPEND_xxx in first argument }
else if (
"SUSPEND_EVENT_THREAD".
equals(
args[
0])) {
* Ask for Exception events * Ask for method entry events * Ask for method exit events * We are now set up to receive the notifications we want. * Here we go. This adds 'this' as a listener so * that our handlers above will be called. throw new Exception(
"MethodEntryExitEvents: failed");