[5/6]kernel32/tests: test Fiber callback count

André Hentschel nerv at dawncrow.de
Sun Jan 24 09:31:02 CST 2010


---
 dlls/kernel32/tests/fiber.c |    9 +++++++++
 1 files changed, 9 insertions(+), 0 deletions(-)

diff --git a/dlls/kernel32/tests/fiber.c b/dlls/kernel32/tests/fiber.c
index 95e9953..dac9d6a 100644
--- a/dlls/kernel32/tests/fiber.c
+++ b/dlls/kernel32/tests/fiber.c
@@ -35,6 +35,7 @@ static BOOL (WINAPI *pFlsSetValue)(DWORD,PVOID);
 
 static LPVOID fibers[2];
 static BYTE testparam = 185;
+static WORD cbCount;
 
 static VOID init_funcs(void)
 {
@@ -58,12 +59,14 @@ static VOID init_funcs(void)
 
 static VOID WINAPI FiberLocalStorageProc(PVOID lpFlsData)
 {
+    cbCount++;
     ok(lpFlsData == (PVOID) 1587, "FlsData expected not to be changed\n");
 }
 
 static VOID WINAPI FiberMainProc(LPVOID lpFiberParameter)
 {
     BYTE *tparam = (BYTE *)lpFiberParameter;
+    cbCount++;
     ok(*tparam == 185, "Parameterdata expected not to be changed\n");
     pSwitchToFiber(fibers[0]);
 }
@@ -108,6 +111,7 @@ static void test_ConvertFiberToThread(void)
 
 static void test_FiberHandling(void)
 {
+    cbCount = 0;
     fibers[0] = pCreateFiber(0,FiberMainProc,&testparam);
     ok(fibers[0] != 0, "CreateFiber failed with error %d\n", GetLastError());
     pDeleteFiber(fibers[0]);
@@ -124,6 +128,7 @@ static void test_FiberHandling(void)
     ok(fibers[1] != 0, "CreateFiber failed with error %d\n", GetLastError());
 
     pSwitchToFiber(fibers[1]);
+    ok(cbCount == 1, "Wrong callback count: %d\n", cbCount);
     pDeleteFiber(fibers[1]);
 
     if (!pCreateFiberEx)
@@ -136,6 +141,7 @@ static void test_FiberHandling(void)
     ok(fibers[1] != 0, "CreateFiberEx failed with error %d\n", GetLastError());
 
     pSwitchToFiber(fibers[1]);
+    ok(cbCount == 2, "Wrong callback count: %d\n", cbCount);
     pDeleteFiber(fibers[1]);
 
     if (!pIsThreadAFiber)
@@ -160,6 +166,7 @@ static void test_FiberLocalStorage(PFLS_CALLBACK_FUNCTION cbfunc)
         win_skip( "Fiber Local Storage not supported\n" );
         return;
     }
+    cbCount = 0;
 
     fls = pFlsAlloc(cbfunc);
     ok(fls != FLS_OUT_OF_INDEXES, "FlsAlloc failed with error %d\n", GetLastError());
@@ -170,6 +177,8 @@ static void test_FiberLocalStorage(PFLS_CALLBACK_FUNCTION cbfunc)
 
     ret = pFlsFree(fls);
     ok(ret, "FlsFree failed\n");
+    if (cbfunc)
+        todo_wine ok(cbCount == 1, "Wrong callback count: %d\n", cbCount);
 }
 
 START_TEST(fiber)
-- 

Best Regards, André Hentschel



More information about the wine-patches mailing list