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