diff options
author | Jiyoung Yun <jy910.yun@samsung.com> | 2016-11-23 19:09:09 +0900 |
---|---|---|
committer | Jiyoung Yun <jy910.yun@samsung.com> | 2016-11-23 19:09:09 +0900 |
commit | 4b4aad7217d3292650e77eec2cf4c198ea9c3b4b (patch) | |
tree | 98110734c91668dfdbb126fcc0e15ddbd93738ca /tests/src/baseservices/exceptions/regressions/V1/SEH/VJ/RecursiveException.cs | |
parent | fa45f57ed55137c75ac870356a1b8f76c84b229c (diff) | |
download | coreclr-4b4aad7217d3292650e77eec2cf4c198ea9c3b4b.tar.gz coreclr-4b4aad7217d3292650e77eec2cf4c198ea9c3b4b.tar.bz2 coreclr-4b4aad7217d3292650e77eec2cf4c198ea9c3b4b.zip |
Imported Upstream version 1.1.0upstream/1.1.0
Diffstat (limited to 'tests/src/baseservices/exceptions/regressions/V1/SEH/VJ/RecursiveException.cs')
-rw-r--r-- | tests/src/baseservices/exceptions/regressions/V1/SEH/VJ/RecursiveException.cs | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/tests/src/baseservices/exceptions/regressions/V1/SEH/VJ/RecursiveException.cs b/tests/src/baseservices/exceptions/regressions/V1/SEH/VJ/RecursiveException.cs new file mode 100644 index 0000000000..052a48868a --- /dev/null +++ b/tests/src/baseservices/exceptions/regressions/V1/SEH/VJ/RecursiveException.cs @@ -0,0 +1,50 @@ +// Licensed to the .NET Foundation under one or more agreements. +// The .NET Foundation licenses this file to you under the MIT license. +// See the LICENSE file in the project root for more information. +using System; +using System.Threading; +using System.IO; + +class UserException : Exception { + +} + +public class RecursiveException { + public static int Main(String [] args) { + String s = "Done"; + int retVal = 100; + Thread mv_Thread; + RecursiveException re = new RecursiveException(); + for (int i = 0 ; i < 10; i++){ + mv_Thread = new Thread(new ThreadStart(re.runtest)); + try { + mv_Thread.Start(); + } + catch (Exception ){ + Console.WriteLine("Exception was caught in main"); + retVal = 0; + } + } + Console.WriteLine(s); + return retVal; + } + + public void runtest(){ + try { + recurse(0); + } + catch (UserException ) { + lock(this) + { + Console.WriteLine("The Exception was caught"); + } + } + } + + public void recurse(int counter) { + if (counter == 1000) + throw new UserException(); + else + recurse(++counter); + } +} |