jdk

Форк
0
/
Stack012.java 
129 строк · 4.5 Кб
1
/*
2
 * Copyright (c) 2000, 2024, Oracle and/or its affiliates. All rights reserved.
3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
 *
5
 * This code is free software; you can redistribute it and/or modify it
6
 * under the terms of the GNU General Public License version 2 only, as
7
 * published by the Free Software Foundation.
8
 *
9
 * This code is distributed in the hope that it will be useful, but WITHOUT
10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12
 * version 2 for more details (a copy is included in the LICENSE file that
13
 * accompanied this code).
14
 *
15
 * You should have received a copy of the GNU General Public License version
16
 * 2 along with this work; if not, write to the Free Software Foundation,
17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18
 *
19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20
 * or visit www.oracle.com if you need additional information or have any
21
 * questions.
22
 */
23

24
/*
25
 * @test
26
 * @key stress
27
 *
28
 * @summary converted from VM testbase nsk/stress/stack/stack012.
29
 * VM testbase keywords: [stress, stack, nonconcurrent]
30
 * VM testbase readme:
31
 * DESCRIPTION
32
 *     This test provokes multiple stack overflows in the multiple
33
 *     threads -- by invoking final recursive method for the given
34
 *     fixed depth of recursion (though, for a large depth).
35
 *     This test measures a number of recursive invocations until
36
 *     stack overflow, and then tries to provoke similar stack overflows
37
 *     10 times in each of 10 threads. Each provocation consists of
38
 *     invoking that recursive method for the given fixed depth
39
 *     of invocations which is 100 times that depth measured before.
40
 *     The test is deemed passed, if VM have not crashed, and
41
 *     if exception other than due to stack overflow was not
42
 *     thrown.
43
 * COMMENTS
44
 *     This test crashes HS versions 1.3, 1.4 on Win32, and HS versions
45
 *     2.0, 1.3, and 1.4 on Solaris. However, it passes against HS 2.0
46
 *     on Win32.
47
 *     See the bug:
48
 *     4366625 (P4/S4) multiple stack overflow causes HS crash
49
 *
50
 * @requires vm.opt.DeoptimizeALot != true
51
 * @run main/othervm/timeout=900 Stack012
52
 */
53

54
public class Stack012 extends Thread {
55
    final static int THREADS = 10;
56
    final static int CYCLES = 10;
57

58
    public static void main(String[] args) {
59
        Stack012 test = new Stack012();
60
        //
61
        // Measure maximal recursion depth until stack overflow:
62
        //
63
        int maxDepth = 0;
64
        for (int depth = 10; ; depth += 10) {
65
            try {
66
                test.recurse(depth);
67
                maxDepth = depth;
68
            } catch (StackOverflowError | OutOfMemoryError err) {
69
                break;
70
            }
71
        }
72
        System.out.println("Max. depth: " + maxDepth);
73

74
        //
75
        // Execute multiple threads repeatedly provoking stack overflows:
76
        //
77
        Stack012 threads[] = new Stack012[THREADS];
78
        for (int i = 0; i < threads.length; i++) {
79
            threads[i] = new Stack012();
80
            threads[i].depthToTry = 100 * maxDepth;
81
            threads[i].start();
82
        }
83
        for (int i = 0; i < threads.length; i++) {
84
            if (threads[i].isAlive()) {
85
                try {
86
                    threads[i].join();
87
                } catch (InterruptedException exception) {
88
                    throw new RuntimeException(exception);
89
                }
90
            }
91
        }
92
        //
93
        // Check if unexpected exceptions were not thrown:
94
        //
95
        for (int i = 0; i < threads.length; i++) {
96
            if (threads[i].thrown != null) {
97
                threads[i].thrown.printStackTrace();
98
                throw new RuntimeException("Exception in the thread " + threads[i], threads[i].thrown);
99
            }
100
        }
101
    }
102

103
    int depthToTry = 0;
104
    Throwable thrown = null;
105

106
    public void run() {
107
        for (int i = 0; i < CYCLES; i++) {
108
            try {
109
                this.recurse(depthToTry);
110
                throw new Exception(
111
                        "TEST_RFE: no stack overflow thrown" +
112
                                ", need to try deeper recursion?");
113

114
            } catch (StackOverflowError | OutOfMemoryError err) {
115
                // It's OK
116
            } catch (Throwable throwable) {
117
                // It isn't OK!
118
                thrown = throwable;
119
                break;
120
            }
121
        }
122
    }
123

124
    final void recurse(int depth) {
125
        if (depth > 0) {
126
            recurse(depth - 1);
127
        }
128
    }
129
}
130

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.