File: NotAField.sh

package info (click to toggle)
openjdk-11 11.0.4%2B11-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 757,028 kB
  • sloc: java: 5,016,041; xml: 1,191,974; cpp: 934,731; ansic: 555,697; sh: 24,299; objc: 12,703; python: 3,602; asm: 3,415; makefile: 2,772; awk: 351; sed: 172; perl: 114; jsp: 24; csh: 3
file content (98 lines) | stat: -rw-r--r-- 2,927 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#!/bin/sh

#
# Copyright (c) 2002, 2014, 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
#  @bug 4467887 4913748
#  @summary TTY: NullPointerException at
#           com.sun.tools.jdi.MirrorImpl.validateMirrors
#  @author Tim Bell
#  @key intermittent
#  @run shell NotAField.sh
#

createJavaFile()
{
    cat <<EOF > $classname.java.1
public class $classname {
    public static void main(String args[]) {
        System.out.println("Hello, world!");
    }
}

EOF
}

# This is called to feed cmds to jdb.
dojdbCmds()
{
   #set -x
   cmd stop in $classname.main
   runToBkpt
   #This works:
   cmd print "java.lang.Class.reflectionFactory.hashCode()"
   #This should result in a ParseException: ("No such field in ..."):
   cmd print "java.lang.Class.reflectionFactory.hashCode"
   cmd allowExit cont
}

mysetup()
{
   if [ -z "${TESTJAVA}" ] ; then
      # TESTJAVA is not set, so the test is running stand-alone.
      # TESTJAVA holds the path to the root directory of the build of the JDK
      # to be tested.  That is, any java files run explicitly in this shell
      # should use TESTJAVA in the path to the java interpreter.
      # So, we'll set this to the JDK spec'd on the command line.  If none
      # is given on the command line, tell the user that and use a default.
      # THIS IS THE JDK BEING TESTED.
      if [ -n "$1" ] ; then
             TESTJAVA=$1
         else
             TESTJAVA=$JAVA_HOME
      fi
      TESTSRC=.
      TESTCLASSES=.
   fi
   echo "JDK under test is: $TESTJAVA"

   if [ -z "$TESTSRC" ] ; then
        TESTSRC=.
   fi

   if [ -r $TESTSRC/ShellScaffold.sh ] ; then
        . $TESTSRC/ShellScaffold.sh 
   elif [ -r $TESTSRC/../ShellScaffold.sh ] ; then
        . $TESTSRC/../ShellScaffold.sh
   fi
}

# You could replace this next line with the contents
# of ShellScaffold.sh and this script will run just the same.
mysetup

runit
jdbFailIfNotPresent "com.sun.tools.example.debug.expr.ParseException" 50
pass