jdk/test/com/sun/jdi/LineNumberOnBraceTest.java
author mikejwre
Thu, 25 Mar 2010 15:05:15 -0700
changeset 5074 9c9bfe8f3a47
parent 2 90ce3da70b43
child 24973 8c4bc3fa4c4e
permissions -rw-r--r--
Added tag jdk7-b87 for changeset 8367da959bab

/**
 *  @test/nodynamiccopyright/
 *  @bug 4952629 4870514
 *  @summary REGRESSION: javac generates a spurious line number entry on } else {
 *
 *  @author jjh
 *
 *  @run build VMConnection TargetListener TargetAdapter
 *  @run compile -g LineNumberOnBraceTest.java
 *  @run main LineNumberOnBraceTest
 */
import com.sun.jdi.*;
import com.sun.jdi.event.*;
import com.sun.jdi.request.*;

import java.util.*;

    /********** LINE NUMBER SENSITIVE! *****************************************************************/
class LineNumberOnBraceTarg {

    public final static int stopLine = 28;   // THIS MUST BE THE LINE NUMBER OF THE // stopline LINE
    public final static int stopLine2 = 34;  // THIS MUST BE THE LINE NUMBER OF THE // stopline2 LINE


    public static void main(String[] args){
        System.out.println("Howdy!");
        if (args.length == 0) {
            System.out.println("No args to debuggee");             // stopLine
        } else {
            System.out.println("Some args to debuggee");
        }
        if (args.length == 0) {
            boolean b1 = false;
            if (b1) {                                              // stopLine2
                System.out.println("In 2nd else");                 // bug 4870514 is that we stop here.
            }
        } else {
            System.out.println("In 2nd else");
        }
        System.out.println("Goodbye from LineNumberOnBraceTarg!");  // stopLine2 + 6
    }

    // This isn't part of the test; it is just here
    // so one can see what line numbers are generated for a finally.
    public void exampleOfThrow() {
        try {
            throw new Exception();
        } catch (Exception e) {
            System.out.println("caught exception");
        } finally {
            System.out.println("finally");
        }
    }

}

    /********** test program **********/

public class LineNumberOnBraceTest extends TestScaffold {
    ReferenceType targetClass;
    ThreadReference mainThread;

    LineNumberOnBraceTest (String args[]) {
        super(args);
    }

    public static void main(String[] args)      throws Exception {
        new LineNumberOnBraceTest(args).startTests();
    }
    /********** test core **********/

    protected void runTests() throws Exception {
        /*
         * Get to the top of main()
         * to determine targetClass and mainThread
         */
        BreakpointEvent bpe = startToMain("LineNumberOnBraceTarg");
        targetClass = bpe.location().declaringType();
        mainThread = bpe.thread();

        resumeTo("LineNumberOnBraceTarg", LineNumberOnBraceTarg.stopLine);
        StepEvent stepev = stepOverLine(mainThread);       // step to 2nd if (args.length

        // Bug 4952629 is that javac outputs a line number
        // on the goto around the else which causes us to
        // be stopped at that goto instead of the println("Goodbye ...")

        int ln = stepev.location().lineNumber();
        System.out.println("Debuggee is stopped at line " + ln);
        if (ln != LineNumberOnBraceTarg.stopLine + 4) {
            failure("FAIL: Bug 4952629: Should be at line " +
                    (LineNumberOnBraceTarg.stopLine + 4) +
                    ", am at " + ln);
        } else {
            System.out.println("Passed test for 4952629");
        }

        // Test for bug 4870514
        System.out.println("Resuming to " + LineNumberOnBraceTarg.stopLine2);
        resumeTo("LineNumberOnBraceTarg", LineNumberOnBraceTarg.stopLine2);
        System.out.println("Stopped at " + LineNumberOnBraceTarg.stopLine2);
        stepev = stepOverLine(mainThread);
        ln = stepev.location().lineNumber();
        System.out.println("Debuggee is stopped at line " + ln);
        if (ln == LineNumberOnBraceTarg.stopLine2 + 1) {
            failure("FAIL: bug 4870514: Incorrectly stopped at " +
                    (LineNumberOnBraceTarg.stopLine2 + 1));
        } else {
            System.out.println("Passed test for 4870514");
        }


        /*
         * resume the target listening for events
         */
        listenUntilVMDisconnect();

        /*
         * deal with results of test
         * if anything has called failure("foo") testFailed will be true
         */
        if (!testFailed) {
            println("LineNumberOnBraceTest: passed");
        } else {
            throw new Exception("LineNumberOnBraceTest: failed");
        }
    }
}