StackTrace2.java 1.99 KB
Newer Older
1 2 3
// Check that stack trace's work, and stack trace line numbers, if available,
// are correct.

4
public class StackTrace2
5 6 7 8 9
{
  public static void main(String[] args) 
  { 
    try
    {
10
      new StackTrace2().a();
11 12 13 14 15 16 17 18
    }
    catch (Exception x)
    {
      StackTraceElement[] trace = x.getStackTrace();
      checkTrace(trace);
    }
  }

19
  void a() 
20
  { 
21
    new Inner().foo();
22 23
  }
  
24
  class Inner
25
  {
26
    public void foo()
27 28 29 30 31 32 33 34 35 36 37 38 39
    {
      doCrash(null);
    }  

    public void doCrash(Object o)
    {
      o.toString();
    }
  }  
  
  static void checkTrace(StackTraceElement[] trace)
  {
    System.out.println("Trace length = " + trace.length);
40
    checkLine(trace[0], "StackTrace2$Inner", "doCrash", 33);
41
    checkLine(trace[1], "StackTrace2$Inner", "foo", 28);
42 43
    checkLine(trace[2], "StackTrace2", "a", 21);
    checkLine(trace[3], "StackTrace2", "main", 10);
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
  }
  
  static void checkLine(StackTraceElement frame, String expected_cl, 
                	String expected_method, int expected_line)
  {
    if (frame.getClassName().equals(expected_cl))
      System.out.print(expected_cl);
    else
      System.out.print("FAIL - expected " + expected_cl + ", got: " + 
		       frame.getClassName());
    
    System.out.print(".");

    if (frame.getMethodName().equals(expected_method))
      System.out.print(expected_method);
    else
      System.out.print("FAIL - expected " + expected_method + ", got: " +
		       frame.getMethodName());

    System.out.print(":");
    
    // Permit either the correct line number or no line number. This is so
    // we don't fail on platforms that don't yet support reading debug info 
    // for stack traces, or when no debug info is available.
    if (frame.getLineNumber() < 0
        || (frame.getLineNumber() == expected_line
70
            && frame.getFileName().equals("StackTrace2.java")))
71 72
      System.out.println("OK");
    else
Tom Tromey committed
73 74 75
      System.out.println("FAIL - expected " + expected_line + ", got: "
			 + frame.getLineNumber() + ", in file "
			 + frame.getFileName());
76 77
  }
}