Piotr Caban : msvcp90/tests: Added char_traits<char>::_Copy_s tests.
Alexandre Julliard
julliard at winehq.org
Wed Jul 21 10:54:48 CDT 2010
Module: wine
Branch: master
Commit: 166b7f4ffba5b556c00f6cfac85aff73165d8480
URL: http://source.winehq.org/git/wine.git/?a=commit;h=166b7f4ffba5b556c00f6cfac85aff73165d8480
Author: Piotr Caban <piotr at codeweavers.com>
Date: Tue Jul 20 23:25:07 2010 +0200
msvcp90/tests: Added char_traits<char>::_Copy_s tests.
---
dlls/msvcp90/tests/misc.c | 52 +++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 52 insertions(+), 0 deletions(-)
diff --git a/dlls/msvcp90/tests/misc.c b/dlls/msvcp90/tests/misc.c
index 10616a9..0fe28ce 100644
--- a/dlls/msvcp90/tests/misc.c
+++ b/dlls/msvcp90/tests/misc.c
@@ -32,6 +32,8 @@ static BYTE (__cdecl *p_char_eq)(const void*, const void*);
static BYTE (__cdecl *p_wchar_eq)(const void*, const void*);
static BYTE (__cdecl *p_short_eq)(const void*, const void*);
+static char* (__cdecl *p_Copy_s)(char*, unsigned int, const char*, unsigned int);
+
static int invalid_parameter = 0;
static void __cdecl test_invalid_parameter_handler(const wchar_t *expression,
const wchar_t *function, const wchar_t *file,
@@ -70,6 +72,8 @@ static BOOL init(void)
p_wchar_eq = (void*)GetProcAddress(msvcp, "?eq@?$char_traits at _W@std@@SA_NAB_W0 at Z");
p_short_eq = (void*)GetProcAddress(msvcp, "?eq@?$char_traits at G@std@@SA_NABG0 at Z");
+ p_Copy_s = (void*)GetProcAddress(msvcp, "?_Copy_s@?$char_traits at D@std@@SAPADPADIPBDI at Z");
+
return TRUE;
}
@@ -136,6 +140,53 @@ static void test_equal(void)
ok(ret == FALSE, "ret = %d\n", (int)ret);
}
+static void test_Copy_s(void)
+{
+ static const char src[] = "abcd";
+ char dest[32], *ret;
+
+ if(!p_Copy_s) {
+ win_skip("Copy_s tests skipped\n");
+ return;
+ }
+
+ dest[4] = '#';
+ dest[5] = '\0';
+ ret = p_Copy_s(dest, 4, src, 4);
+ ok(ret == dest, "ret != dest\n");
+ ok(dest[4] == '#', "dest[4] != '#'\n");
+ ok(!memcmp(dest, src, sizeof(char[4])), "dest = %s\n", dest);
+
+ ret = p_Copy_s(dest, 32, src, 4);
+ ok(ret == dest, "ret != dest\n");
+ ok(dest[4] == '#', "dest[4] != '#'\n");
+ ok(!memcmp(dest, src, sizeof(char[4])), "dest = %s\n", dest);
+
+ errno = 0xdeadbeef;
+ dest[0] = '#';
+ ret = p_Copy_s(dest, 3, src, 4);
+ ok(ret == dest, "ret != dest\n");
+ ok(dest[0] == '\0', "dest[0] != 0\n");
+ ok(invalid_parameter==1, "invalid_parameter = %d\n",
+ invalid_parameter);
+ invalid_parameter = 0;
+ ok(errno == 0xdeadbeef, "errno = %d\n", errno);
+
+ errno = 0xdeadbeef;
+ p_Copy_s(NULL, 32, src, 4);
+ ok(invalid_parameter==1, "invalid_parameter = %d\n",
+ invalid_parameter);
+ invalid_parameter = 0;
+ ok(errno == 0xdeadbeef, "errno = %d\n", errno);
+
+ errno = 0xdeadbeef;
+ p_Copy_s(dest, 32, NULL, 4);
+ ok(invalid_parameter==1, "invalid_parameter = %d\n",
+ invalid_parameter);
+ invalid_parameter = 0;
+ ok(errno == 0xdeadbeef, "errno = %d\n", errno);
+}
+
START_TEST(misc)
{
if(!init())
@@ -143,6 +194,7 @@ START_TEST(misc)
test_assign();
test_equal();
+ test_Copy_s();
ok(!invalid_parameter, "invalid_parameter_handler was invoked too many times\n");
}
More information about the wine-cvs
mailing list