diff options
Diffstat (limited to 'src/pal/tests/palsuite/exception_handling/PAL_TRY_EXCEPT_EX/test3/PAL_TRY_EXCEPT_EX.c')
-rw-r--r-- | src/pal/tests/palsuite/exception_handling/PAL_TRY_EXCEPT_EX/test3/PAL_TRY_EXCEPT_EX.c | 130 |
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.c b/src/pal/tests/palsuite/exception_handling/PAL_TRY_EXCEPT_EX/test3/PAL_TRY_EXCEPT_EX.c 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.c @@ -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; + +} |