test/hotspot/jtreg/vmTestbase/nsk/jdwp/StackFrame/GetValues/getvalues001/TestDescription.java
changeset 50317 cf71bff5f533
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/test/hotspot/jtreg/vmTestbase/nsk/jdwp/StackFrame/GetValues/getvalues001/TestDescription.java	Wed May 30 20:54:45 2018 -0700
@@ -0,0 +1,78 @@
+/*
+ * Copyright (c) 2017, 2018, 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.
+ */
+
+
+/*
+ * @test
+ *
+ * @summary converted from VM Testbase nsk/jdwp/StackFrame/GetValues/getvalues001.
+ * VM Testbase keywords: [quick, jpda, jdwp]
+ * VM Testbase readme:
+ * DESCRIPTION
+ *     This test performs checking for
+ *         command set: StackFrame
+ *         command: GetValues
+ *     Test checks that debugee accept the command packet and
+ *     replies with correct reply packet. Also test checks that
+ *     returned values for requested local variables is the same
+ *     as expected.
+ *     Test consists of two compoments:
+ *         debugger: getvalues001
+ *         debuggee: getvalues001a
+ *     First, debugger uses nsk.share support classes to launch debuggee
+ *     and obtain Transport object, that represents JDWP transport channel.
+ *     Also communication channel (IOPipe) is established between
+ *     debugger and debuggee to exchange with synchronization signals.
+ *     Next, debugger obtains from debuggee classID for tested class
+ *     and object ID and threadID as values of the class static fields.
+ *     Also debugger suspends the thread and gets frameID for the
+ *     current thread frameID and indexes of its local variables.
+ *     Thread is suspended on the invokation of method for the tested object.
+ *     Then, debugger creates command packet for StackFrame.GetValues
+ *     command with the found threadID, frameID and indexes of local variables
+ *     as arguments, writes packet to the transport channel, and waits
+ *     for a reply packet.
+ *     When reply packet is received, debugger parses the packet structure
+ *     and extracts variables values. Also test checks that returned values
+ *     are equals to the expected ones.
+ *     Finally, debugger sends debuggee signal to quit, waits for it exits
+ *     and exits too with the proper exit code.
+ *
+ * @library /vmTestbase /test/hotspot/jtreg/vmTestbase
+ *          /test/lib
+ * @run driver jdk.test.lib.FileInstaller . .
+ * @build nsk.jdwp.StackFrame.GetValues.getvalues001
+ *        nsk.jdwp.StackFrame.GetValues.getvalues001a
+ * @comment debuggee should be compiled w/ debug info
+ * @clean nsk.jdwp.StackFrame.GetValues.getvalues001a
+ * @compile -g:lines,source,vars ../getvalues001a.java
+ * @run main/othervm PropertyResolvingWrapper
+ *      nsk.jdwp.StackFrame.GetValues.getvalues001
+ *      -arch=${os.family}-${os.simpleArch}
+ *      -verbose
+ *      -waittime=5
+ *      -debugee.vmkind=java
+ *      -transport.address=dynamic
+ *      -debugee.vmkeys="${test.vm.opts} ${test.java.opts}"
+ */
+