perfsrv/piprofiler/engine/test/piprofilertest/src/piprofilertest.cpp
author hgs
Tue, 26 Oct 2010 16:20:32 +0300
changeset 62 1c2bb2fc7c87
permissions -rw-r--r--
201043
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
62
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
//  Include Files  
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
#include "piprofilertest.h"
hgs
parents:
diff changeset
    21
#include <e32base.h>
hgs
parents:
diff changeset
    22
#include <e32std.h>
hgs
parents:
diff changeset
    23
#include <e32cons.h>			// Console
hgs
parents:
diff changeset
    24
#include <e32debug.h>
hgs
parents:
diff changeset
    25
#include "rtestsampler.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
//  Constants
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
_LIT(KTextConsoleTitle, "Console");
hgs
parents:
diff changeset
    30
_LIT(KTextFailed, " failed, leave code = %d");
hgs
parents:
diff changeset
    31
_LIT(KTextPressAnyKey, " [press any key]\n");
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
//  Global Variables
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
LOCAL_D CConsoleBase* console; // write all messages to this
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
//  Local Functions
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
LOCAL_C void MainL()
hgs
parents:
diff changeset
    41
    {
hgs
parents:
diff changeset
    42
    //
hgs
parents:
diff changeset
    43
    // add your program code here, example code below
hgs
parents:
diff changeset
    44
    //
hgs
parents:
diff changeset
    45
    //console->Write(_L("Hello, world!\n"));
hgs
parents:
diff changeset
    46
    RDebug::Printf("hallo welt\n");
hgs
parents:
diff changeset
    47
    //LoadProfilerLDD();
hgs
parents:
diff changeset
    48
    
hgs
parents:
diff changeset
    49
    RDebug::Printf("hallo ldd\n");
hgs
parents:
diff changeset
    50
    LoadProfilerDLL();
hgs
parents:
diff changeset
    51
    RDebug::Printf("hallo2\n");
hgs
parents:
diff changeset
    52
    }
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
LOCAL_C void DoStartL()
hgs
parents:
diff changeset
    55
    {
hgs
parents:
diff changeset
    56
    // Create active scheduler (to run active objects)
hgs
parents:
diff changeset
    57
    CActiveScheduler* scheduler = new (ELeave) CActiveScheduler();
hgs
parents:
diff changeset
    58
    CleanupStack::PushL(scheduler);
hgs
parents:
diff changeset
    59
    CActiveScheduler::Install(scheduler);
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
    MainL();
hgs
parents:
diff changeset
    62
    
hgs
parents:
diff changeset
    63
    // Delete active scheduler
hgs
parents:
diff changeset
    64
    CleanupStack::PopAndDestroy(scheduler);
hgs
parents:
diff changeset
    65
    }
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
//  Global Functions
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
GLDEF_C TInt E32Main()
hgs
parents:
diff changeset
    70
    {
hgs
parents:
diff changeset
    71
    // Create cleanup stack
hgs
parents:
diff changeset
    72
    __UHEAP_MARK;
hgs
parents:
diff changeset
    73
    CTrapCleanup* cleanup = CTrapCleanup::New();
hgs
parents:
diff changeset
    74
    // Create output console
hgs
parents:
diff changeset
    75
//    TRAPD(createError, console = Console::NewL(KTextConsoleTitle, TSize(
hgs
parents:
diff changeset
    76
//            KConsFullScreen, KConsFullScreen)));
hgs
parents:
diff changeset
    77
//    if (createError)
hgs
parents:
diff changeset
    78
//        {
hgs
parents:
diff changeset
    79
//        delete cleanup;
hgs
parents:
diff changeset
    80
//        return createError;
hgs
parents:
diff changeset
    81
//        }
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
    // Run application code inside TRAP harness, wait keypress when terminated
hgs
parents:
diff changeset
    84
    TRAPD(mainError, DoStartL());
hgs
parents:
diff changeset
    85
    if (mainError)
hgs
parents:
diff changeset
    86
//        console->Printf(KTextFailed, mainError);
hgs
parents:
diff changeset
    87
//    console->Printf(KTextPressAnyKey);
hgs
parents:
diff changeset
    88
//    console->Getch();
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
//    delete console;
hgs
parents:
diff changeset
    91
    delete cleanup;
hgs
parents:
diff changeset
    92
    __UHEAP_MARKEND;
hgs
parents:
diff changeset
    93
    return KErrNone;
hgs
parents:
diff changeset
    94
    }
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
LOCAL_C TInt LoadProfilerLDD()
hgs
parents:
diff changeset
    97
   {
hgs
parents:
diff changeset
    98
    RDebug::Printf("LoadProfilerLDD >");
hgs
parents:
diff changeset
    99
    TInt err;        
hgs
parents:
diff changeset
   100
    _LIT(KPluginSamplerName,"PIProfilerGeneralsSampler");
hgs
parents:
diff changeset
   101
    err = User::LoadLogicalDevice(KPluginSamplerName);
hgs
parents:
diff changeset
   102
    RDebug::Printf("Err2 : %d", err);
hgs
parents:
diff changeset
   103
    if(err == KErrAlreadyExists)
hgs
parents:
diff changeset
   104
        {
hgs
parents:
diff changeset
   105
        err = User::FreeLogicalDevice(KPluginSamplerName);
hgs
parents:
diff changeset
   106
        RDebug::Printf("Err2.1 : %d", err);
hgs
parents:
diff changeset
   107
        err = User::LoadLogicalDevice(KPluginSamplerName);
hgs
parents:
diff changeset
   108
        RDebug::Printf("Err2.2 : %d", err);
hgs
parents:
diff changeset
   109
        }
hgs
parents:
diff changeset
   110
    RtestSampler aGeneralsSampler;
hgs
parents:
diff changeset
   111
    err = aGeneralsSampler.Open();
hgs
parents:
diff changeset
   112
    RDebug::Printf("Err3 : %d", err);
hgs
parents:
diff changeset
   113
    if(err = KErrNone)
hgs
parents:
diff changeset
   114
        {
hgs
parents:
diff changeset
   115
        RDebug::Printf("test - Could not open sampler device: %d", err);
hgs
parents:
diff changeset
   116
        // Sets test case result and description(Maximum size is KStifMaxResultDes)
hgs
parents:
diff changeset
   117
        _LIT( KDescription, "Could not open sampler device" );
hgs
parents:
diff changeset
   118
        //aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   119
        }
hgs
parents:
diff changeset
   120
    
hgs
parents:
diff changeset
   121
    // Case was executed
hgs
parents:
diff changeset
   122
    err = User::FreeLogicalDevice(KPluginSamplerName);
hgs
parents:
diff changeset
   123
    RDebug::Printf("Err4 : %d", err);
hgs
parents:
diff changeset
   124
    
hgs
parents:
diff changeset
   125
    RDebug::Printf("LoadProfilerLDD <");
hgs
parents:
diff changeset
   126
    return KErrNone;
hgs
parents:
diff changeset
   127
   }
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
LOCAL_C TInt LoadProfilerDLL()
hgs
parents:
diff changeset
   130
   {    
hgs
parents:
diff changeset
   131
        RDebug::Printf("LoadProfilerDLL >");
hgs
parents:
diff changeset
   132
        RLibrary lib;
hgs
parents:
diff changeset
   133
        TInt err = lib.Load(_L("PIProfilerGenerals.dll"), _L("c:\\sys\\bin"));
hgs
parents:
diff changeset
   134
        RDebug::Printf("Err0 : %d", err);
hgs
parents:
diff changeset
   135
        
hgs
parents:
diff changeset
   136
        const TInt KNewLOrdinal = 2;
hgs
parents:
diff changeset
   137
        TLibraryFunction NewL =lib.Lookup(KNewLOrdinal);                
hgs
parents:
diff changeset
   138
        RDebug::Printf("library.lookup returns 0x%x", NewL);
hgs
parents:
diff changeset
   139
        CSamplerPluginInterface* mydll;
hgs
parents:
diff changeset
   140
        //STF_ASSERT_LEAVES_WITH (KErrPermissionDenied, (mydll=(CSamplerPluginInterface*)NewL()));
hgs
parents:
diff changeset
   141
        mydll=(CSamplerPluginInterface*)NewL();
hgs
parents:
diff changeset
   142
        
hgs
parents:
diff changeset
   143
        if( mydll )
hgs
parents:
diff changeset
   144
            {
hgs
parents:
diff changeset
   145
                // Sets test case result and description(Maximum size is KStifMaxResultDes)
hgs
parents:
diff changeset
   146
                _LIT( KDescription, "mydll exists" );
hgs
parents:
diff changeset
   147
                //aResult.SetResult( KErrAccessDenied, KDescription );
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
            }
hgs
parents:
diff changeset
   150
        else
hgs
parents:
diff changeset
   151
            {
hgs
parents:
diff changeset
   152
                // Sets test case result and description(Maximum size is KStifMaxResultDes)
hgs
parents:
diff changeset
   153
                _LIT( KDescription, "passed" );
hgs
parents:
diff changeset
   154
                //aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   155
            }
hgs
parents:
diff changeset
   156
        
hgs
parents:
diff changeset
   157
        // Case was executed
hgs
parents:
diff changeset
   158
        RDebug::Printf("LoadProfilerDLL <");
hgs
parents:
diff changeset
   159
        return KErrNone;
hgs
parents:
diff changeset
   160
   }
hgs
parents:
diff changeset
   161