=?UTF-8?Q?Iv=C3=A1n=20Matellanes=20?=: msvcirt/tests: Add tests of ostrstream::pcount.

Alexandre Julliard julliard at winehq.org
Thu Oct 20 18:32:46 CDT 2016


Module: wine
Branch: master
Commit: 2d4e7d405055b3151c4cd5ac9a2c2f6bf0ce3b8a
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=2d4e7d405055b3151c4cd5ac9a2c2f6bf0ce3b8a

Author: Iván Matellanes <matellanesivan at gmail.com>
Date:   Wed Oct 19 14:00:54 2016 +0200

msvcirt/tests: Add tests of ostrstream::pcount.

Signed-off-by: Iván Matellanes <matellanesivan at gmail.com>
Signed-off-by: Piotr Caban <piotr at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/msvcirt/tests/msvcirt.c | 26 ++++++++++++++++++++++++++
 1 file changed, 26 insertions(+)

diff --git a/dlls/msvcirt/tests/msvcirt.c b/dlls/msvcirt/tests/msvcirt.c
index e656866..db3ee3b 100644
--- a/dlls/msvcirt/tests/msvcirt.c
+++ b/dlls/msvcirt/tests/msvcirt.c
@@ -336,6 +336,7 @@ static ostream* (*__thiscall p_ostrstream_ctor)(ostream*, BOOL);
 static void (*__thiscall p_ostrstream_dtor)(ios*);
 static void (*__thiscall p_ostrstream_vbase_dtor)(ostream*);
 static ostream* (*__thiscall p_ostrstream_assign)(ostream*, const ostream*);
+static int (*__thiscall p_ostrstream_pcount)(const ostream*);
 
 /* istream */
 static istream* (*__thiscall p_istream_copy_ctor)(istream*, const istream*, BOOL);
@@ -608,6 +609,7 @@ static BOOL init(void)
         SET(p_ostrstream_dtor, "??1ostrstream@@UEAA at XZ");
         SET(p_ostrstream_vbase_dtor, "??_Dostrstream@@QEAAXXZ");
         SET(p_ostrstream_assign, "??4ostrstream@@QEAAAEAV0 at AEBV0@@Z");
+        SET(p_ostrstream_pcount, "?pcount at ostrstream@@QEBAHXZ");
 
         SET(p_istream_copy_ctor, "??0istream@@IEAA at AEBV0@@Z");
         SET(p_istream_ctor, "??0istream@@IEAA at XZ");
@@ -794,6 +796,7 @@ static BOOL init(void)
         SET(p_ostrstream_dtor, "??1ostrstream@@UAE at XZ");
         SET(p_ostrstream_vbase_dtor, "??_Dostrstream@@QAEXXZ");
         SET(p_ostrstream_assign, "??4ostrstream@@QAEAAV0 at ABV0@@Z");
+        SET(p_ostrstream_pcount, "?pcount at ostrstream@@QBEHXZ");
 
         SET(p_istream_copy_ctor, "??0istream@@IAE at ABV0@@Z");
         SET(p_istream_ctor, "??0istream@@IAE at XZ");
@@ -3996,6 +3999,7 @@ static void test_ostrstream(void)
     ostream os1, os2, *pos, *pos2;
     strstreambuf *pssb;
     char buffer[32];
+    int ret;
 
     memset(&os1, 0xab, sizeof(ostream));
     memset(&os2, 0xab, sizeof(ostream));
@@ -4253,6 +4257,28 @@ static void test_ostrstream(void)
     ok(os2.base_ios.fill == ' ', "expected 32 got %d\n", os2.base_ios.fill);
     ok(os2.base_ios.width == 0, "expected 0 got %d\n", os2.base_ios.width);
     ok(os2.base_ios.do_lock == 0xabababab, "expected %d got %d\n", 0xabababab, os2.base_ios.do_lock);
+
+    /* pcount */
+    pos = call_func2(p_ostrstream_ctor, &os1, TRUE);
+    ok(pos == &os1, "wrong return, expected %p got %p\n", &os1, pos);
+    ret = (int) call_func1(p_ostrstream_pcount, &os1);
+    ok(ret == 0, "expected 0 got %d\n", ret);
+    pssb = (strstreambuf*) os1.base_ios.sb;
+    pssb->base.pptr = (char*) 5;
+    ret = (int) call_func1(p_ostrstream_pcount, &os1);
+    ok(ret == 5, "expected 5 got %d\n", ret);
+    pssb->base.pbase = (char*) 2;
+    ret = (int) call_func1(p_ostrstream_pcount, &os1);
+    ok(ret == 3, "expected 3 got %d\n", ret);
+    pssb->base.pptr = NULL;
+    ret = (int) call_func1(p_ostrstream_pcount, &os1);
+    ok(ret == 0, "expected 0 got %d\n", ret);
+    if (0) /* crashes on native */
+        os1.base_ios.sb = NULL;
+    pssb->base.pptr = (char*) 1;
+    ret = (int) call_func1(p_ostrstream_pcount, &os1);
+    ok(ret == 0, "expected 0 got %d\n", ret);
+    call_func1(p_ostrstream_vbase_dtor, &os1);
 }
 
 static void test_istream(void)




More information about the wine-cvs mailing list