kerneltest/e32test/resourceman/t_rescontrolclisync.cpp
branchRCL_3
changeset 43 c1f20ce4abcf
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kerneltest/e32test/resourceman/t_rescontrolclisync.cpp	Tue Aug 31 16:34:26 2010 +0300
@@ -0,0 +1,120 @@
+// Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of the License "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// e32test\resourceman\t_rescontrolclisync.cpp
+// TestCase Description:
+// This test harness is to test the unsafe setup of power request call back object
+// inside resourcecontrol.cpp. The memeber variable of TPowerRequestCb should not 
+// be corrupted when a second ChangeResourceState is execute during the call back
+// function is running.
+// 
+//
+
+#include <e32test.h>
+#include <e32hal.h>
+#include <e32math.h>
+#include <e32def.h>
+#include <e32def_private.h>
+#include "d_rescontrolclisync.h"
+
+
+
+LOCAL_D RTest test(_L("T_RESCONTROLCLISYNC"));
+RTestResMan lddChan;
+RTestResMan lddChan2;
+
+#define TESTANDCLEAN(x) TestAndClean(x,__LINE__)
+
+void TestAndClean(TBool aTestValid, TInt aLine)
+    {
+    if(!aTestValid)
+        {
+        lddChan.DeRegisterClient();
+        lddChan2.DeRegisterClient();
+        lddChan.Close();
+        lddChan2.Close();
+        User::FreeLogicalDevice(KLddFileName);
+        User::FreePhysicalDevice(KPddFileName);
+        RDebug::Printf("Test fail at line %d", aLine);
+        test.HandleError(EFalse, aLine, (TText *)__FILE__);
+        }
+    }
+
+GLDEF_C TInt E32Main()
+	{
+	test.Title();
+	test.Start(_L("Testing Resource Manager...\n"));
+
+	test.Next(_L("Load Physical device"));
+	TInt r = User::LoadPhysicalDevice(KPddFileName);
+	test(r==KErrNone || r==KErrAlreadyExists);
+	test.Next(_L("Load Logical Device"));
+	r=User::LoadLogicalDevice(KLddFileName);
+	test(r==KErrNone || r==KErrAlreadyExists);
+    test.Next(_L("Open Logical Channel 1"));	
+	r = lddChan.Open();
+    test(r==KErrNone);	
+    test.Next(_L("Open Logical Channel 2"));        
+	r = lddChan2.Open();
+	test(r==KErrNone);
+
+    test.Next(_L("Register client 1"));    
+	r = lddChan.RegisterClient();
+    RDebug::Printf("Register client 1 return r = %d", r);
+    TESTANDCLEAN(r==KErrNone);
+
+	test.Next(_L("Register client 2"));    
+	r = lddChan2.RegisterClient();
+    RDebug::Printf("Register client 2 return r = %d", r);
+    TESTANDCLEAN(r==KErrNone);
+    
+    test.Next(_L("Print resource info"));    
+    r = lddChan.PrintResourceInfo();
+    RDebug::Printf("Print resource info return r = %d", r);
+    TESTANDCLEAN(r==KErrNone);
+
+    TRequestStatus RequestStatus;
+    TRequestStatus RequestStatus2;
+    
+    test.Next(_L("WaitAndChangeResource"));    
+    lddChan.WaitAndChangeResource(RequestStatus);
+
+    test.Next(_L("ChangeResourceAndSignal"));    
+    lddChan2.ChangeResourceAndSignal(RequestStatus2);
+
+    User::WaitForRequest(RequestStatus);
+    TESTANDCLEAN(RequestStatus.Int()==KErrNone);
+    User::WaitForRequest(RequestStatus2);
+    TESTANDCLEAN(RequestStatus2.Int()==KErrNone);
+
+    test.Next(_L("De-register client 1")); 
+	r = lddChan.DeRegisterClient();
+    test(r==KErrNone);
+    
+    test.Next(_L("De-register client 2")); 	
+    r = lddChan2.DeRegisterClient();
+    test(r==KErrNone);
+    
+	test.Printf(_L("Closing the channel\n"));
+	lddChan.Close();
+	lddChan2.Close();
+	test.Printf(_L("Freeing logical device\n"));
+	r = User::FreeLogicalDevice(KLddFileName);
+	test(r==KErrNone);
+	r = User::FreePhysicalDevice(KPddFileName);
+	test(r==KErrNone);
+	test.End();
+	test.Close();
+	return KErrNone;
+	}
+