1 /* 2 * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. 8 * 9 * This code is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 12 * version 2 for more details (a copy is included in the LICENSE file that 13 * accompanied this code). 14 * 15 * You should have received a copy of the GNU General Public License version 16 * 2 along with this work; if not, write to the Free Software Foundation, 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 18 * 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 20 * or visit www.oracle.com if you need additional information or have any 21 * questions. 22 */ 23 24 25 /* 26 * @test 27 * 28 * @summary converted from VM Testbase nsk/jdi/ThreadStartRequest/addThreadFilter/addthreadfilter002. 29 * VM Testbase keywords: [quick, jpda, jdi] 30 * VM Testbase readme: 31 * DESCRIPTION: 32 * The test for the implementation of an object of the type 33 * ThreadStartRequest. 34 * The test checks up that a result of the method 35 * com.sun.jdi.ThreadStartRequest.addThreadFilter() 36 * complies with its spec: 37 * public void addThreadFilter(ThreadReference thread) 38 * Restricts the events generated by this request to those in the given thread. 39 * Parameters: thread - the thread to filter on. 40 * Throws: InvalidRequestStateException - 41 * if this request is currently enabled or has been deleted. 42 * Filters may be added only to disabled requests. 43 * The test checks that "if this request is currently enabled" 44 * calling the method results in throwing InvalidRequestStateException. 45 * The test works as follows: 46 * The debugger program - nsk.jdi.ThreadStartRequest.addThreadFilter.addthreadfilter002; 47 * the debuggee program - nsk.jdi.ThreadStartRequest.addThreadFilter.addthreadfilter002a. 48 * Using nsk.jdi.share classes, 49 * the debugger gets the debuggee running on another JavaVM, 50 * creates the object debuggee.VM, and waits for VMStartEvent. 51 * Upon getting the debuggee VM started, 52 * the debugger calls corresponding debuggee.VM methods to get 53 * needed data and to perform checks. 54 * In case of error the test produces the return value 97 and 55 * a corresponding error message(s). 56 * Otherwise, the test is passed and produces 57 * the return value 95 and no message. 58 * COMMENTS: 59 * 60 * @library /vmTestbase 61 * /test/lib 62 * @build nsk.jdi.ThreadStartRequest.addThreadFilter.addthreadfilter002 63 * nsk.jdi.ThreadStartRequest.addThreadFilter.addthreadfilter002a 64 * @run main/othervm 65 * nsk.jdi.ThreadStartRequest.addThreadFilter.addthreadfilter002 66 * -verbose 67 * -arch=${os.family}-${os.simpleArch} 68 * -waittime=5 69 * -debugee.vmkind=java 70 * -transport.address=dynamic 71 * -debugee.vmkeys="${test.vm.opts} ${test.java.opts}" 72 */ 73 74