--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/perfsrv/piprofiler/engine/test/piprofilertest/src/piprofilertest.cpp Tue Oct 26 16:20:32 2010 +0300
@@ -0,0 +1,161 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "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:
+*
+*/
+
+// Include Files
+
+#include "piprofilertest.h"
+#include <e32base.h>
+#include <e32std.h>
+#include <e32cons.h> // Console
+#include <e32debug.h>
+#include "rtestsampler.h"
+
+// Constants
+
+_LIT(KTextConsoleTitle, "Console");
+_LIT(KTextFailed, " failed, leave code = %d");
+_LIT(KTextPressAnyKey, " [press any key]\n");
+
+// Global Variables
+
+LOCAL_D CConsoleBase* console; // write all messages to this
+
+
+// Local Functions
+
+LOCAL_C void MainL()
+ {
+ //
+ // add your program code here, example code below
+ //
+ //console->Write(_L("Hello, world!\n"));
+ RDebug::Printf("hallo welt\n");
+ //LoadProfilerLDD();
+
+ RDebug::Printf("hallo ldd\n");
+ LoadProfilerDLL();
+ RDebug::Printf("hallo2\n");
+ }
+
+LOCAL_C void DoStartL()
+ {
+ // Create active scheduler (to run active objects)
+ CActiveScheduler* scheduler = new (ELeave) CActiveScheduler();
+ CleanupStack::PushL(scheduler);
+ CActiveScheduler::Install(scheduler);
+
+ MainL();
+
+ // Delete active scheduler
+ CleanupStack::PopAndDestroy(scheduler);
+ }
+
+// Global Functions
+
+GLDEF_C TInt E32Main()
+ {
+ // Create cleanup stack
+ __UHEAP_MARK;
+ CTrapCleanup* cleanup = CTrapCleanup::New();
+ // Create output console
+// TRAPD(createError, console = Console::NewL(KTextConsoleTitle, TSize(
+// KConsFullScreen, KConsFullScreen)));
+// if (createError)
+// {
+// delete cleanup;
+// return createError;
+// }
+
+ // Run application code inside TRAP harness, wait keypress when terminated
+ TRAPD(mainError, DoStartL());
+ if (mainError)
+// console->Printf(KTextFailed, mainError);
+// console->Printf(KTextPressAnyKey);
+// console->Getch();
+
+// delete console;
+ delete cleanup;
+ __UHEAP_MARKEND;
+ return KErrNone;
+ }
+
+LOCAL_C TInt LoadProfilerLDD()
+ {
+ RDebug::Printf("LoadProfilerLDD >");
+ TInt err;
+ _LIT(KPluginSamplerName,"PIProfilerGeneralsSampler");
+ err = User::LoadLogicalDevice(KPluginSamplerName);
+ RDebug::Printf("Err2 : %d", err);
+ if(err == KErrAlreadyExists)
+ {
+ err = User::FreeLogicalDevice(KPluginSamplerName);
+ RDebug::Printf("Err2.1 : %d", err);
+ err = User::LoadLogicalDevice(KPluginSamplerName);
+ RDebug::Printf("Err2.2 : %d", err);
+ }
+ RtestSampler aGeneralsSampler;
+ err = aGeneralsSampler.Open();
+ RDebug::Printf("Err3 : %d", err);
+ if(err = KErrNone)
+ {
+ RDebug::Printf("test - Could not open sampler device: %d", err);
+ // Sets test case result and description(Maximum size is KStifMaxResultDes)
+ _LIT( KDescription, "Could not open sampler device" );
+ //aResult.SetResult( KErrNone, KDescription );
+ }
+
+ // Case was executed
+ err = User::FreeLogicalDevice(KPluginSamplerName);
+ RDebug::Printf("Err4 : %d", err);
+
+ RDebug::Printf("LoadProfilerLDD <");
+ return KErrNone;
+ }
+
+LOCAL_C TInt LoadProfilerDLL()
+ {
+ RDebug::Printf("LoadProfilerDLL >");
+ RLibrary lib;
+ TInt err = lib.Load(_L("PIProfilerGenerals.dll"), _L("c:\\sys\\bin"));
+ RDebug::Printf("Err0 : %d", err);
+
+ const TInt KNewLOrdinal = 2;
+ TLibraryFunction NewL =lib.Lookup(KNewLOrdinal);
+ RDebug::Printf("library.lookup returns 0x%x", NewL);
+ CSamplerPluginInterface* mydll;
+ //STF_ASSERT_LEAVES_WITH (KErrPermissionDenied, (mydll=(CSamplerPluginInterface*)NewL()));
+ mydll=(CSamplerPluginInterface*)NewL();
+
+ if( mydll )
+ {
+ // Sets test case result and description(Maximum size is KStifMaxResultDes)
+ _LIT( KDescription, "mydll exists" );
+ //aResult.SetResult( KErrAccessDenied, KDescription );
+
+ }
+ else
+ {
+ // Sets test case result and description(Maximum size is KStifMaxResultDes)
+ _LIT( KDescription, "passed" );
+ //aResult.SetResult( KErrNone, KDescription );
+ }
+
+ // Case was executed
+ RDebug::Printf("LoadProfilerDLL <");
+ return KErrNone;
+ }
+