summaryrefslogtreecommitdiff
path: root/src/pal/tests/palsuite/exception_handling/PAL_TRY_EXCEPT_EX/test3/PAL_TRY_EXCEPT_EX.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/pal/tests/palsuite/exception_handling/PAL_TRY_EXCEPT_EX/test3/PAL_TRY_EXCEPT_EX.cpp')
-rw-r--r--src/pal/tests/palsuite/exception_handling/PAL_TRY_EXCEPT_EX/test3/PAL_TRY_EXCEPT_EX.cpp130
1 files changed, 130 insertions, 0 deletions
diff --git a/src/pal/tests/palsuite/exception_handling/PAL_TRY_EXCEPT_EX/test3/PAL_TRY_EXCEPT_EX.cpp b/src/pal/tests/palsuite/exception_handling/PAL_TRY_EXCEPT_EX/test3/PAL_TRY_EXCEPT_EX.cpp
new file mode 100644
index 0000000000..d6a948926b
--- /dev/null
+++ b/src/pal/tests/palsuite/exception_handling/PAL_TRY_EXCEPT_EX/test3/PAL_TRY_EXCEPT_EX.cpp
@@ -0,0 +1,130 @@
+// 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.
+
+/*=====================================================================
+**
+** Source: PAL_TRY_EXCEPT.c (test 3)
+**
+** Purpose: Tests the PAL implementation of the PAL_TRY and
+** PAL_EXCEPT functions. Force an exception in only one block
+** to ensure the proper exception block is hit.
+**
+**
+**===================================================================*/
+
+
+
+#include <palsuite.h>
+
+
+int __cdecl main(int argc, char *argv[])
+{
+ int* p = 0x00000000; /* NULL pointer */
+ BOOL bTry = FALSE;
+ BOOL bExcept = FALSE;
+ BOOL bTestA = TRUE;
+
+ if (0 != PAL_Initialize(argc, argv))
+ {
+ return FAIL;
+ }
+
+
+ /*
+ ** test to make sure we get into the exception block
+ */
+
+ PAL_TRY
+ {
+ if (!bTestA)
+ {
+ Fail("PAL_TRY_EXCEPT: ERROR ->"
+ " It appears the first try block was hit a second time.\n");
+ }
+ bTry = TRUE; /* indicate we hit the PAL_TRY block */
+ *p = 13; /* causes an access violation exception */
+ Fail("PAL_TRY_EXCEPT: ERROR -> code was executed after the "
+ "access violation.\n");
+ }
+ PAL_EXCEPT(EXCEPTION_EXECUTE_HANDLER)
+ {
+ if (!bTestA)
+ {
+ Fail("PAL_TRY_EXCEPT: ERROR ->"
+ " It appears the first except block was hit a second time.\n");
+ }
+ bExcept = TRUE; /* indicate we hit the PAL_EXCEPT block */
+ }
+ PAL_ENDTRY;
+
+ if (!bTry)
+ {
+ Trace("PAL_TRY_EXCEPT: ERROR -> It appears the code in the PAL_TRY"
+ " block was not executed.\n");
+ }
+
+ if (!bExcept)
+ {
+ Trace("PAL_TRY_EXCEPT: ERROR -> It appears the code in the first"
+ " PAL_EXCEPT block was not executed.\n");
+ }
+
+ /* did we hit all the code blocks? */
+ if(!bTry || !bExcept)
+ {
+ Fail("\n");
+ }
+
+
+ /*
+ ** test to make sure we get into the second exception block
+ */
+
+ bTry = FALSE;
+ bExcept = FALSE;
+ bTestA = FALSE; /* we are now going into the second block test */
+
+
+ PAL_TRY
+ {
+ if (bTestA)
+ {
+ Fail("PAL_TRY_EXCEPT: ERROR -> It appears"
+ " the second try block was hit too early.\n");
+ }
+ bTry = TRUE; /* indicate we hit the PAL_TRY block */
+ }
+ PAL_EXCEPT(EXCEPTION_EXECUTE_HANDLER)
+ {
+ if (bTestA)
+ {
+ Fail("PAL_TRY_EXCEPT: ERROR -> It appears"
+ " the second except block was hit too early.\n");
+ }
+ bExcept = TRUE; /* indicate we hit the PAL_EXCEPT block */
+ }
+ PAL_ENDTRY;
+
+ if (!bTry)
+ {
+ Trace("PAL_TRY_EXCEPT: ERROR -> It appears the code in the second"
+ " PAL_TRY block was not executed.\n");
+ }
+
+ if (bExcept)
+ {
+ Trace("PAL_TRY_EXCEPT: ERROR -> It appears the code in the second "
+ " PAL_EXCEPT block was executed for some reason.\n");
+ }
+
+ /* did we hit all the correct code blocks? */
+ if(!bTry || bExcept)
+ {
+ Fail("\n");
+ }
+
+ PAL_Terminate();
+ return PASS;
+
+}