summaryrefslogtreecommitdiff
path: root/tests/059-finalizer-throw/src/Main.java
blob: 42260e434cd6d6ba0ed7d807c5cde28d9a22aab6 (plain)
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
// Copyright 2008 The Android Open Source Project

import java.util.Timer;
import java.util.TimerTask;

/*
 * Throw an exception from a finalizer and make sure it's harmless.  Under
 * Dalvik this may also generate a warning in the log file.
 */
public class Main {
    static Object waiter = new Object();
    static volatile boolean didFinal = false;

    static void createAndForget() {
        Main main = new Main();
    }

    public static void main(String[] args) {
        createAndForget();

        System.gc();
        System.runFinalization();

        new Timer(true).schedule(new TimerTask() {
                public void run() {
                    System.out.println("Timed out, exiting");
                    System.exit(1);
                }
            }, 30000);

        while (!didFinal) {
            try {
                Thread.sleep(500);
            } catch (InterruptedException ie) {
                System.err.println(ie);
            }
        }

        /* give it a chance to cause mayhem */
        try {
            Thread.sleep(750);
        } catch (InterruptedException ie) {
            System.err.println(ie);
        }

        System.out.println("done");
    }

    protected void finalize() throws Throwable {
        System.out.println("In finalizer");

        didFinal = true;

        throw new InterruptedException("whee");
    }
}