diff options
Diffstat (limited to 'src/pal/tests/palsuite/miscellaneous/wsprintfW/test13/test.c')
-rw-r--r-- | src/pal/tests/palsuite/miscellaneous/wsprintfW/test13/test.c | 126 |
1 files changed, 126 insertions, 0 deletions
diff --git a/src/pal/tests/palsuite/miscellaneous/wsprintfW/test13/test.c b/src/pal/tests/palsuite/miscellaneous/wsprintfW/test13/test.c new file mode 100644 index 0000000000..dd0daae0a0 --- /dev/null +++ b/src/pal/tests/palsuite/miscellaneous/wsprintfW/test13/test.c @@ -0,0 +1,126 @@ +// 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: test.c +** +** Purpose: Test for wsprintfW() function +** +** +**=========================================================*/ + +#define UNICODE +#include <palsuite.h> + +char * ErrorMessage = NULL; +WCHAR * BadResult = NULL; +WCHAR buf[256]; + +/* memcmp is used to verify the results, so this test is dependent on it. */ +/* ditto with strlen */ + +BOOL test1() +{ + int pos = 0x1234ab; + + wsprintf(buf, convert("foo %X"), pos); + if (memcmp(buf, convert("foo 1234AB"), wcslen(buf)*2 + 2) != 0) + { + ErrorMessage = "ERROR: (Test 1) Failed. The correct string is" + " 'foo 1234AB' and the result returned was "; + BadResult = buf; + return FAIL; + } + + wsprintf(buf, convert("foo %lX"), pos); + if (memcmp(buf, convert("foo 1234AB"), wcslen(buf)*2 + 2) != 0) + { + ErrorMessage = "ERROR: (Test 2) Failed. The correct string is" + " 'foo 1234AB' and the result returned was "; + BadResult = buf; + return FAIL; + } + + wsprintf(buf, convert("foo %7X"), pos); + if (memcmp(buf, convert("foo 1234AB"), wcslen(buf)*2 + 2) != 0) + { + ErrorMessage = "ERROR: (Test 3) Failed. The correct string is" + " 'foo 1234AB' and the result returned was "; + BadResult = buf; + return FAIL; + } + + wsprintf(buf, convert("foo %-7X"), pos); + if (memcmp(buf, convert("foo 1234AB "), wcslen(buf)*2 + 2) != 0) + { + ErrorMessage = "ERROR: (Test 4) Failed. The correct string is" + " 'foo 1234AB ' and the result returned was "; + BadResult = buf; + return FAIL; + } + + wsprintf(buf, convert("foo %.1X"), pos); + if (memcmp(buf, convert("foo 1234AB"), wcslen(buf)*2 + 2) != 0) + { + ErrorMessage = "ERROR: (Test 5) Failed. The correct string is" + " 'foo 1234AB' and the result returned was "; + BadResult = buf; + return FAIL; + } + + wsprintf(buf, convert("foo %.7X"), pos); + if (memcmp(buf, convert("foo 01234AB"), wcslen(buf)*2 + 2) != 0) + { + ErrorMessage = "ERROR: (Test 6) Failed. The correct string is" + " 'foo 01234AB' and the result returned was "; + BadResult = buf; + return FAIL; + } + + wsprintf(buf, convert("foo %07X"), pos); + if (memcmp(buf, convert("foo 01234AB"), wcslen(buf)*2 + 2) != 0) + { + ErrorMessage = "ERROR: (Test 7) Failed. The correct string is" + " 'foo 01234AB' and the result returned was "; + BadResult = buf; + return FAIL; + } + + wsprintf(buf, convert("foo %#X"), pos); + if (memcmp(buf, convert("foo 0X1234AB"), wcslen(buf)*2 + 2) != 0) + { + ErrorMessage = "ERROR: (Test 8) Failed. The correct string is" + " 'foo 0X1234AB' and the result returned was "; + BadResult = buf; + return FAIL; + } + + return PASS; +} + +int __cdecl main(int argc, char *argv[]) +{ + + /* + * Initialize the PAL and return FAILURE if this fails + */ + + if(0 != (PAL_Initialize(argc, argv))) + { + return FAIL; + } + + if(test1()) + { + Fail("%s '%s'\n",ErrorMessage,convertC(BadResult)); + + } + + PAL_Terminate(); + return PASS; + +} + + |