services/terminalmodeservice/tsrc/upnptmservertest/src/tmservertestcases.cpp
author hgs
Fri, 23 Jul 2010 08:57:49 +0300
changeset 24 e9457ebcc4df
child 26 b6b8e90f9863
permissions -rw-r--r--
201029
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
24
hgs
parents:
diff changeset
     1
/**
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 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
hgs
parents:
diff changeset
    19
// INCLUDE FILES
hgs
parents:
diff changeset
    20
#include <e32math.h>
hgs
parents:
diff changeset
    21
#include "tmservertest.h"
hgs
parents:
diff changeset
    22
#include <ecom/ecom.h>
hgs
parents:
diff changeset
    23
#include "testtimer.h"
hgs
parents:
diff changeset
    24
#include "discoverytesttimer.h"
hgs
parents:
diff changeset
    25
#include <upnpdevice.h>
hgs
parents:
diff changeset
    26
#include <upnptmserverdeviceinfo.h>
hgs
parents:
diff changeset
    27
#include <upnpsettings.h>
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
// LOCAL CONSTANTS AND MACROS
hgs
parents:
diff changeset
    30
_LIT8(KTestSvgMimeType,           "image/svg+xml");
hgs
parents:
diff changeset
    31
_LIT8(KTmServerDevice,            "urn:schemas-upnp-org:device:TmServerDevice:1" );
hgs
parents:
diff changeset
    32
_LIT8(KTmServerService,           "urn:schemas-upnp-org:service:TmApplicationServer:1" );
hgs
parents:
diff changeset
    33
_LIT8(KTmServerServiceType,       "TmApplicationServer:1" );
hgs
parents:
diff changeset
    34
_LIT8(KTmServerServiceType1,      "TmClientProfile:1" );
hgs
parents:
diff changeset
    35
_LIT8(KBtMacValue,                "00257df016d5");
hgs
parents:
diff changeset
    36
_LIT8(KArgTypeAppStatusUpdate,    "AppStatusUpdate");
hgs
parents:
diff changeset
    37
_LIT8(KGetAppStatus,              "GetApplicationStatus");
hgs
parents:
diff changeset
    38
_LIT8(KAppStatus,                 "AppStatus");
hgs
parents:
diff changeset
    39
_LIT8(KGetApplicationList,        "GetApplicationList");
hgs
parents:
diff changeset
    40
_LIT8(KAppListing,                "AppListing");
hgs
parents:
diff changeset
    41
_LIT8(KLaunchApp,                 "LaunchApplication");
hgs
parents:
diff changeset
    42
_LIT8(KTerminateApp,              "TerminateApplication");
hgs
parents:
diff changeset
    43
_LIT8(KAppLaunchStatus,           "AppURI");
hgs
parents:
diff changeset
    44
_LIT8(KAppTerminateStatus,        "TerminationResult");
hgs
parents:
diff changeset
    45
_LIT8(KAppId ,                    "AppID");
hgs
parents:
diff changeset
    46
_LIT8(KAppFilter,                 "AppListingFilter");
hgs
parents:
diff changeset
    47
_LIT8(KResultProfile ,            "resultProfile");
hgs
parents:
diff changeset
    48
_LIT8(KSetClientProfile ,         "SetClientProfile");
hgs
parents:
diff changeset
    49
_LIT8(KGetClientProfile,          "GetClientProfile");
hgs
parents:
diff changeset
    50
_LIT8(KGetMaxNumProfiles,         "GetMaxNumProfiles");
hgs
parents:
diff changeset
    51
_LIT8(KClientProfile ,            "clientProfile");
hgs
parents:
diff changeset
    52
_LIT8(KNumProfilesAllowed ,       "numProfilesAllowed");
hgs
parents:
diff changeset
    53
_LIT8(KProfileId,                 "ProfileID");
hgs
parents:
diff changeset
    54
_LIT8(KProfileId1,                "profileID");
hgs
parents:
diff changeset
    55
_LIT8(KBackground,                "Background");
hgs
parents:
diff changeset
    56
_LIT8(KForeground,                "Foreground");
hgs
parents:
diff changeset
    57
_LIT8(KAppListFilterValue1,       "\"icon@mimetype=\"*svg+xml*\",icon@width=\"*\",icon@height=\"*\",icon@depth=\"*\"\"");
hgs
parents:
diff changeset
    58
_LIT8(KAppListFilterValue2,       "\"name=\"*nav*\",description=\"*\",appInfo@appCategory=\"*\",displayInfo@contentCategory=\"*\",allowedProfileIDs=\"*\"\"");
hgs
parents:
diff changeset
    59
_LIT8(KAppListFilterValue3,       "\"name=\"*bluetooth*\",description=\"*\",icon@mimetype=\"*svg+xml*\",remotingInfo@protocolID=\"*\",appInfo@appCategory=\"*\",audioInfo@audioType=\"*\",resourceStatus=\"free\",signature=\"*\"\"");
hgs
parents:
diff changeset
    60
_LIT8(KAppListFilterValue4,       "\"name=\"*\",description=\"*Audio*\",icon@mimetype=\"*svg+xml*\",remotingInfo@protocolID=\"*\",appInfo@appCategory=\"*\",audioInfo@audioType=\"*\",resourceStatus=\"free\",signature=\"*\"\"");
hgs
parents:
diff changeset
    61
_LIT8(KWildCard,                  "*");
hgs
parents:
diff changeset
    62
_LIT(KIconPathMusicUnLaunched,          "c:\\upnptmserver\\icons\\music_unlaunched.svg");
hgs
parents:
diff changeset
    63
_LIT(KIconPathMusicLaunched,            "c:\\upnptmserver\\icons\\music_launched.svg");
hgs
parents:
diff changeset
    64
_LIT(KIconPathMaps,                     "c:\\upnptmserver\\icons\\maps.svg");
hgs
parents:
diff changeset
    65
_LIT(KIconPathBtA2DpUnLaunched,         "c:\\upnptmserver\\icons\\gallery.svg");
hgs
parents:
diff changeset
    66
_LIT(KIconPathBtA2DpLaunched,           "c:\\upnptmserver\\icons\\homemedia.svg");
hgs
parents:
diff changeset
    67
_LIT(KIconPathBtHfp,                    "c:\\upnptmserver\\icons\\videos.svg");
hgs
parents:
diff changeset
    68
_LIT(KIconDevicePath,                   "c:\\upnptmserver\\icons\\s60_device.svg");    
hgs
parents:
diff changeset
    69
_LIT8(KDeviceInfo,                      "<X_Nokia_deviceInfo><version><major>1</major><minor>0</minor></version><mtp_tc>true</mtp_tc>"
hgs
parents:
diff changeset
    70
    "<license_model>pre,post</license_model><sound_feedback><enabled>true</enabled></sound_feedback><ipRouting><enabled>false</enabled></ipRouting>"
hgs
parents:
diff changeset
    71
    "</X_Nokia_deviceInfo>");
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
_LIT8(KClientProfileInfo, "&lt;clientProfile&gt;&lt;clientID&gt;Cl_1&lt;/clientID&gt;&lt;friendlyName&gt;Client One&lt;/friendlyName&gt;&lt;manufacturer&gt;man_2&lt;/manufacturer&gt;&lt;modelName&gt;CL_Model2&lt;/modelName&gt;&lt;modelNumber&gt;2009&lt;/modelNumber&gt;&lt;iconPreference&gt;&lt;width&gt;240&lt;/width&gt;&lt;height&gt;240&lt;/height&gt;&lt;/iconPreference&gt;&lt;contentRules&gt;&lt;rule&gt;&lt;ruleId&gt;0&lt;/ruleId&gt;&lt;ruleValue&gt;0.1&lt;/ruleValue&gt;&lt;/rule&gt;&lt;rule&gt;&lt;ruleId&gt;1&lt;/ruleId&gt;&lt;/rule&gt;&lt;/contentRules&gt;&lt;/clientProfile&gt;");
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
_LIT8(KDeviceLockedClientProfile, "&lt;clientProfile&gt;&lt;clientID&gt;Cl_2&lt;/clientID&gt;&lt;/clientProfile&gt;");
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
_LIT8(KXmlSignature, "&lt;Signature Id= &quot;AppListSignature&quot; xmlns=&quot;http://www.w3.org/2000/09/xmldsig#&quot;&gt; &lt;SignedInfo&gt;&lt;CanonicalizationMethod Algorithm=&quot;http://www.w3.org/2006/12/xml-c14n11&quot;/&gt;&lt;SignatureMethodAlgorithm=&quot;http://www.w3.org/2000/09/xmldsig#dsa-sha1&quot;/&gt; &lt;Reference URI=&quot;&quot;&gt;&lt;/Reference&gt;&lt;/SignedInfo&gt;&lt;/Signature&gt;");
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
// ============================ MEMBER FUNCTIONS ===============================
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    82
// CTmServerTest::Case
hgs
parents:
diff changeset
    83
// Returns a test case by number.
hgs
parents:
diff changeset
    84
//
hgs
parents:
diff changeset
    85
// This function contains an array of all available test cases 
hgs
parents:
diff changeset
    86
// i.e pair of case name and test function. If case specified by parameter
hgs
parents:
diff changeset
    87
// aCaseNumber is found from array, then that item is returned.
hgs
parents:
diff changeset
    88
// 
hgs
parents:
diff changeset
    89
// The reason for this rather complicated function is to specify all the
hgs
parents:
diff changeset
    90
// test cases only in one place. It is not necessary to understand how
hgs
parents:
diff changeset
    91
// function pointers to class member functions works when adding new test
hgs
parents:
diff changeset
    92
// cases. See function body for instructions how to add new test case.
hgs
parents:
diff changeset
    93
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    94
//
hgs
parents:
diff changeset
    95
const TCaseInfo CTmServerTest::Case ( 
hgs
parents:
diff changeset
    96
    const TInt aCaseNumber ) const 
hgs
parents:
diff changeset
    97
     {
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
    /**
hgs
parents:
diff changeset
   100
    * To add new test cases, implement new test case function and add new 
hgs
parents:
diff changeset
   101
    * line to KCases array specify the name of the case and the function 
hgs
parents:
diff changeset
   102
    * doing the test case
hgs
parents:
diff changeset
   103
    * In practice, do following
hgs
parents:
diff changeset
   104
    * 1) Make copy of existing test case function and change its name
hgs
parents:
diff changeset
   105
    *    and functionality. Note that the function must be added to 
hgs
parents:
diff changeset
   106
    *    TmServerTest.cpp file and to TmServerTest.h 
hgs
parents:
diff changeset
   107
    *    header file.
hgs
parents:
diff changeset
   108
    *
hgs
parents:
diff changeset
   109
    * 2) Add entry to following KCases array either by using:
hgs
parents:
diff changeset
   110
    *
hgs
parents:
diff changeset
   111
    * 2.1: FUNCENTRY or ENTRY macro
hgs
parents:
diff changeset
   112
    * ENTRY macro takes two parameters: test case name and test case 
hgs
parents:
diff changeset
   113
    * function name.
hgs
parents:
diff changeset
   114
    *
hgs
parents:
diff changeset
   115
    * FUNCENTRY macro takes only test case function name as a parameter and
hgs
parents:
diff changeset
   116
    * uses that as a test case name and test case function name.
hgs
parents:
diff changeset
   117
    *
hgs
parents:
diff changeset
   118
    * Or
hgs
parents:
diff changeset
   119
    *
hgs
parents:
diff changeset
   120
    * 2.2: OOM_FUNCENTRY or OOM_ENTRY macro. Note that these macros are used
hgs
parents:
diff changeset
   121
    * only with OOM (Out-Of-Memory) testing!
hgs
parents:
diff changeset
   122
    *
hgs
parents:
diff changeset
   123
    * OOM_ENTRY macro takes five parameters: test case name, test case 
hgs
parents:
diff changeset
   124
    * function name, TBool which specifies is method supposed to be run using
hgs
parents:
diff changeset
   125
    * OOM conditions, TInt value for first heap memory allocation failure and 
hgs
parents:
diff changeset
   126
    * TInt value for last heap memory allocation failure.
hgs
parents:
diff changeset
   127
    * 
hgs
parents:
diff changeset
   128
    * OOM_FUNCENTRY macro takes test case function name as a parameter and uses
hgs
parents:
diff changeset
   129
    * that as a test case name, TBool which specifies is method supposed to be
hgs
parents:
diff changeset
   130
    * run using OOM conditions, TInt value for first heap memory allocation 
hgs
parents:
diff changeset
   131
    * failure and TInt value for last heap memory allocation failure. 
hgs
parents:
diff changeset
   132
    */ 
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
    static TCaseInfoInternal const KCases[] =
hgs
parents:
diff changeset
   135
        {
hgs
parents:
diff changeset
   136
        // [test cases entries] - do not remove
hgs
parents:
diff changeset
   137
        
hgs
parents:
diff changeset
   138
        ENTRY( "Start TM Server Device", CTmServerTest::StartTmServerDeviceL ),
hgs
parents:
diff changeset
   139
        ENTRY( "Publish TM Server Service", CTmServerTest::PublishTmServerServiceL ),
hgs
parents:
diff changeset
   140
        ENTRY( "Stop TM Server Device", CTmServerTest::StopTmServerDeviceL ),
hgs
parents:
diff changeset
   141
        ENTRY( "ReStart TM Server Device", CTmServerTest::ReStartTmServerDeviceL ),         
hgs
parents:
diff changeset
   142
        ENTRY( "Handle LaunchApp Command", CTmServerTest::HandleLaunchAppActionL ),
hgs
parents:
diff changeset
   143
        ENTRY( "Handle Invalid AppId LaunchApp Command", CTmServerTest::HandleInvalidAppIdLaunchAppActionL ),
hgs
parents:
diff changeset
   144
        ENTRY( "Handle Invalid ProfileId LaunchApp Command", CTmServerTest::HandleInvalidProfileIdLaunchAppActionL ),
hgs
parents:
diff changeset
   145
        ENTRY( "Handle LaunchApp Command For Non-Existent AppID", CTmServerTest::HandleNonExistentLaunchAppActionL ),
hgs
parents:
diff changeset
   146
        ENTRY( "Handle LaunchApp Command For UnAuthorized AppID", CTmServerTest::HandleUnauthorizedLaunchAppActionL ),
hgs
parents:
diff changeset
   147
        ENTRY( "Handle Device Locked Condition For LaunchApp Command", CTmServerTest::HandleDeviceLockedLaunchAppActionL ),
hgs
parents:
diff changeset
   148
        ENTRY( "Handle TerminateApp Command", CTmServerTest::HandleTerminateAppActionL),
hgs
parents:
diff changeset
   149
        ENTRY( "Handle TerminateApp Command For Non-Existent AppID", CTmServerTest::HandleNonExistentTerminateAppActionL),
hgs
parents:
diff changeset
   150
        ENTRY( "Handle Invalid AppId TerminateApp Command", CTmServerTest::HandleInvalidAppIdTerminateAppActionL),
hgs
parents:
diff changeset
   151
        ENTRY( "Handle Invalid ProfileId TerminateApp Command", CTmServerTest::HandleInvalidProfileIdTerminateAppActionL),
hgs
parents:
diff changeset
   152
        ENTRY( "Handle TerminateApp Command For UnAuthorized AppID", CTmServerTest::HandleUnauthorizedTerminateAppActionL),
hgs
parents:
diff changeset
   153
        ENTRY( "Handle Device Locked Condition For TerminateApp Command", CTmServerTest::HandleDeviceLockedTerminateAppActionL ),
hgs
parents:
diff changeset
   154
        ENTRY( "Handle GetAppStatus Command ", CTmServerTest::HandleGetAppStatusActionL ),
hgs
parents:
diff changeset
   155
        ENTRY( "Handle GetAppStatus Command For All the Applications", CTmServerTest::HandleWildcardGetAppStatusActionL ),
hgs
parents:
diff changeset
   156
        ENTRY( "Handle GetAppStatus Command For Invalid AppId", CTmServerTest::HandleInvalidAppIdGetAppStatusActionL ),
hgs
parents:
diff changeset
   157
        ENTRY( "Handle GetAppStatus Command For Non-Existent AppID", CTmServerTest::HandleNonExistentGetAppStatusActionL ),
hgs
parents:
diff changeset
   158
        ENTRY( "Handle GetAppList Command with Filter1", CTmServerTest:: HandleGetAppListActionFilter1L ), 
hgs
parents:
diff changeset
   159
        ENTRY( "Handle GetAppList Command with Filter2", CTmServerTest:: HandleGetAppListActionFilter2L ),
hgs
parents:
diff changeset
   160
        ENTRY( "Handle GetAppList Command with Filter3", CTmServerTest:: HandleGetAppListActionFilter3L ),  
hgs
parents:
diff changeset
   161
        ENTRY( "Handle GetAppList Command with Filter4", CTmServerTest:: HandleGetAppListActionFilter4L ), 
hgs
parents:
diff changeset
   162
        ENTRY( "Handle GetAppList Command with No Filter", CTmServerTest:: HandleGetAppListActionNoFilterL ), 
hgs
parents:
diff changeset
   163
        ENTRY( "Handle GetAppList Command with Invalid Arg1", CTmServerTest:: HandleGetAppListActionInvalidArg1L ), 
hgs
parents:
diff changeset
   164
        ENTRY( "Handle GetAppList Command with Invalid Arg2", CTmServerTest:: HandleGetAppListActionInvalidArg2L ),
hgs
parents:
diff changeset
   165
        ENTRY( "Handle GetAppList Command with Invalid Arg3", CTmServerTest:: HandleGetAppListActionInvalidArg3L ),
hgs
parents:
diff changeset
   166
        ENTRY( "Handle GetAppList Command with Invalid Arg4", CTmServerTest:: HandleGetAppListActionInvalidArg4L ),
hgs
parents:
diff changeset
   167
        ENTRY( "Handle GetAppList Command with Invalid Arg5", CTmServerTest:: HandleGetAppListActionInvalidArg5L ),
hgs
parents:
diff changeset
   168
        ENTRY( "Handle Invalid ProfileId GetAppList Command", CTmServerTest:: HandleInvalidProfileIdGetAppListActionL),
hgs
parents:
diff changeset
   169
        ENTRY( "Handle Operation Rejected Condition For GetAppList Command", CTmServerTest:: HandleGetAppListActionOperationRejectedL), 
hgs
parents:
diff changeset
   170
        ENTRY( "Handle SetClientProfile Command", CTmServerTest:: HandleSetClientProfileActionL ),  
hgs
parents:
diff changeset
   171
        ENTRY( "Handle Invalid ProfileId SetClientProfile Command", CTmServerTest:: HandleInvalidProfileIdSetClientProfileActionL ), 
hgs
parents:
diff changeset
   172
        ENTRY( "Handle Invalid Profile SetClientProfile Command", CTmServerTest:: HandleInvalidProfileSetClientProfileActionL ),
hgs
parents:
diff changeset
   173
        ENTRY( "Handle Device Locked Condition For SetClientProfile Command", CTmServerTest:: HandleDeviceLockedSetClientProfileActionL ),
hgs
parents:
diff changeset
   174
        ENTRY( "Handle Resource Busy Condition For SetClientProfile Command", CTmServerTest:: HandleResourceBusySetClientProfileActionL ),
hgs
parents:
diff changeset
   175
        ENTRY( "Handle GetClientProfile Command", CTmServerTest:: HandleGetClientProfileActionL ), 
hgs
parents:
diff changeset
   176
        ENTRY( "Handle Invalid ProfileId GetClientProfile Command", CTmServerTest:: HandleInvalidProfileIdGetClientProfileActionL ), 
hgs
parents:
diff changeset
   177
        ENTRY( "Handle GetMaxNumProfiles Command", CTmServerTest:: HandleGetMaxNumProfilesActionL ), 
hgs
parents:
diff changeset
   178
        ENTRY( "Handle Operation Rejected Condition For GetMaxNumProfiles Command", CTmServerTest:: HandleGetMaxNumProfilesOperationRejectedL ),
hgs
parents:
diff changeset
   179
        ENTRY( "Register Duplicate Application", CTmServerTest::RegisterDuplicateAppL),  
hgs
parents:
diff changeset
   180
        ENTRY( "Register Duplicate Applications", CTmServerTest::RegisterDuplicateAppsL),       
hgs
parents:
diff changeset
   181
        ENTRY( "UnRegister Application", CTmServerTest::UnRegisterAppL),        
hgs
parents:
diff changeset
   182
        ENTRY( "UnRegister Multiple Applications", CTmServerTest::UnRegisterAppsL),
hgs
parents:
diff changeset
   183
        ENTRY( "UnRegister UnRegistered Application", CTmServerTest::UnRegisterUnRegisteredAppL),
hgs
parents:
diff changeset
   184
        ENTRY( "UnRegister Multiple UnRegistered Applications", CTmServerTest::UnRegisterUnRegisteredAppsL),
hgs
parents:
diff changeset
   185
        ENTRY( "Handle Event For AppStatus Update", CTmServerTest::HandleEventAppStatusUpdateL ),
hgs
parents:
diff changeset
   186
        ENTRY( "Handle Event For AppList Update", CTmServerTest::HandleEventAppListUpdateL ),
hgs
parents:
diff changeset
   187
        ENTRY( "Handle Event For Duplicate AppStatus Update", CTmServerTest::HandleEventDuplicateAppStatusUpdateL),
hgs
parents:
diff changeset
   188
        ENTRY( "Handle Event For ProfileIdList Status Update", CTmServerTest::HandleEventProfileIdListStatusUpdateL),
hgs
parents:
diff changeset
   189
                
hgs
parents:
diff changeset
   190
        // OOM Testcases    
hgs
parents:
diff changeset
   191
        OOM_ENTRY( "[OOM_StartTmServerDevice]", CTmServerTest::StartTmServerDeviceL,ETrue,1,5 ),
hgs
parents:
diff changeset
   192
        OOM_ENTRY( "[OOM_HandleGetAppListWithFilter]", CTmServerTest:: HandleGetAppListActionFilter1L,ETrue,1,5 ),
hgs
parents:
diff changeset
   193
        OOM_ENTRY( "[OOM_HandleGetAppListWithoutFilter]", CTmServerTest:: HandleGetAppListActionNoFilterL,ETrue,1,5 ),
hgs
parents:
diff changeset
   194
        OOM_ENTRY( "[OOM_HandleSetClientProfileCommand]", CTmServerTest:: HandleSetClientProfileActionL,ETrue,1,5 ),
hgs
parents:
diff changeset
   195
        OOM_ENTRY( "[OOM_HandleGetAppStatusCommand]", CTmServerTest:: HandleGetAppStatusActionL,ETrue,1,5 ),
hgs
parents:
diff changeset
   196
        OOM_ENTRY( "[OOM_HandleGetAppStatusForAllApplications]", CTmServerTest::HandleWildcardGetAppStatusActionL,ETrue,1,5 ),
hgs
parents:
diff changeset
   197
        OOM_ENTRY( "[OOM_HandleAppStatusUpdateEvent]", CTmServerTest::HandleEventAppStatusUpdateL,ETrue,1,5 ),
hgs
parents:
diff changeset
   198
        OOM_ENTRY( "[OOM_HandleDuplicateAppStatusUpdateEvent]", CTmServerTest::HandleEventDuplicateAppStatusUpdateL,ETrue,1,5 ),
hgs
parents:
diff changeset
   199
        OOM_ENTRY( "[OOM_UnRegisterApplications]", CTmServerTest::UnRegisterAppsL,ETrue,1,5 )
hgs
parents:
diff changeset
   200
        };
hgs
parents:
diff changeset
   201
    
hgs
parents:
diff changeset
   202
    // Verify that case number is valid
hgs
parents:
diff changeset
   203
    if( (TUint) aCaseNumber >= sizeof( KCases ) / 
hgs
parents:
diff changeset
   204
                               sizeof( TCaseInfoInternal ) )
hgs
parents:
diff changeset
   205
        {
hgs
parents:
diff changeset
   206
        // Invalid case, construct empty object
hgs
parents:
diff changeset
   207
        TCaseInfo null( (const TText*) L"" );
hgs
parents:
diff changeset
   208
        null.iMethod = NULL;
hgs
parents:
diff changeset
   209
        null.iIsOOMTest = EFalse;
hgs
parents:
diff changeset
   210
        null.iFirstMemoryAllocation = 0;
hgs
parents:
diff changeset
   211
        null.iLastMemoryAllocation = 0;
hgs
parents:
diff changeset
   212
        return null;
hgs
parents:
diff changeset
   213
        } 
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
    // Construct TCaseInfo object and return it
hgs
parents:
diff changeset
   216
    TCaseInfo tmp ( KCases[ aCaseNumber ].iCaseName );
hgs
parents:
diff changeset
   217
    tmp.iMethod = KCases[ aCaseNumber ].iMethod;
hgs
parents:
diff changeset
   218
    tmp.iIsOOMTest = KCases[ aCaseNumber ].iIsOOMTest;
hgs
parents:
diff changeset
   219
    tmp.iFirstMemoryAllocation = KCases[ aCaseNumber ].iFirstMemoryAllocation;
hgs
parents:
diff changeset
   220
    tmp.iLastMemoryAllocation = KCases[ aCaseNumber ].iLastMemoryAllocation;
hgs
parents:
diff changeset
   221
    return tmp;
hgs
parents:
diff changeset
   222
    }
hgs
parents:
diff changeset
   223
hgs
parents:
diff changeset
   224
hgs
parents:
diff changeset
   225
//========================= TEST CASES =======================================================
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
TInt CTmServerTest::StartTmServerDeviceL ( TTestResult& aResult )
hgs
parents:
diff changeset
   228
    {
hgs
parents:
diff changeset
   229
    _LIT( KLogInfo, "Start Terminalmode Server Device" );
hgs
parents:
diff changeset
   230
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   231
    
hgs
parents:
diff changeset
   232
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
   233
    
hgs
parents:
diff changeset
   234
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   235
    SetTmServerSettingsL();     
hgs
parents:
diff changeset
   236
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo,*this );
hgs
parents:
diff changeset
   237
    
hgs
parents:
diff changeset
   238
    //Register all the desired applications 
hgs
parents:
diff changeset
   239
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
   240
    
hgs
parents:
diff changeset
   241
    // Start the tmserver device and its services
hgs
parents:
diff changeset
   242
    iTmServer->StartL();
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
    //Start the control point and search for device
hgs
parents:
diff changeset
   245
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
   246
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   247
    iTestTimer->After(15);
hgs
parents:
diff changeset
   248
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
   249
    
hgs
parents:
diff changeset
   250
    if ( iDeviceVerified)
hgs
parents:
diff changeset
   251
        {
hgs
parents:
diff changeset
   252
        _LIT( KDescription , "Terminalmode Server Device started successfully");
hgs
parents:
diff changeset
   253
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   254
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   255
        }
hgs
parents:
diff changeset
   256
    else
hgs
parents:
diff changeset
   257
        {
hgs
parents:
diff changeset
   258
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   259
        _LIT( KDescription , "Start of Terminalmode Server Device Failed");
hgs
parents:
diff changeset
   260
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   261
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   262
        }
hgs
parents:
diff changeset
   263
    
hgs
parents:
diff changeset
   264
    delete iTestTimer;
hgs
parents:
diff changeset
   265
    iTestTimer = NULL;
hgs
parents:
diff changeset
   266
    REComSession::FinalClose();
hgs
parents:
diff changeset
   267
    return KErrNone;
hgs
parents:
diff changeset
   268
    }
hgs
parents:
diff changeset
   269
hgs
parents:
diff changeset
   270
TInt CTmServerTest::PublishTmServerServiceL ( TTestResult& aResult )
hgs
parents:
diff changeset
   271
    {
hgs
parents:
diff changeset
   272
    _LIT( KLogInfo, "Publish Terminalmode server Service" );
hgs
parents:
diff changeset
   273
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   274
    
hgs
parents:
diff changeset
   275
    iTmServerServiceType = ETrue;
hgs
parents:
diff changeset
   276
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   277
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   278
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo,*this );
hgs
parents:
diff changeset
   279
    
hgs
parents:
diff changeset
   280
    //Register all the desired applications 
hgs
parents:
diff changeset
   281
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
   282
    
hgs
parents:
diff changeset
   283
    //Start the tmserver device and its services
hgs
parents:
diff changeset
   284
    iTmServer->StartL();   
hgs
parents:
diff changeset
   285
    
hgs
parents:
diff changeset
   286
    //Start the control point and search for device
hgs
parents:
diff changeset
   287
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
   288
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   289
    iTestTimer->After(15);
hgs
parents:
diff changeset
   290
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
   291
    
hgs
parents:
diff changeset
   292
    if ( iServiceVerified)
hgs
parents:
diff changeset
   293
        {
hgs
parents:
diff changeset
   294
        _LIT( KDescription , "Terminalmode server Service published successfully");
hgs
parents:
diff changeset
   295
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   296
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   297
        }
hgs
parents:
diff changeset
   298
    else
hgs
parents:
diff changeset
   299
        {
hgs
parents:
diff changeset
   300
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   301
        _LIT( KDescription , "Publishing of Terminalmode server Service Failed");
hgs
parents:
diff changeset
   302
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   303
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   304
        } 
hgs
parents:
diff changeset
   305
    delete iTestTimer;
hgs
parents:
diff changeset
   306
    iTestTimer = NULL;
hgs
parents:
diff changeset
   307
    REComSession::FinalClose();
hgs
parents:
diff changeset
   308
    return KErrNone;
hgs
parents:
diff changeset
   309
    }
hgs
parents:
diff changeset
   310
hgs
parents:
diff changeset
   311
TInt CTmServerTest::StopTmServerDeviceL  ( TTestResult& aResult )
hgs
parents:
diff changeset
   312
    {
hgs
parents:
diff changeset
   313
    _LIT( KLogInfo, "Stop Terminalmode server Device" );
hgs
parents:
diff changeset
   314
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   315
    
hgs
parents:
diff changeset
   316
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
   317
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   318
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   319
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo,*this );
hgs
parents:
diff changeset
   320
    
hgs
parents:
diff changeset
   321
    //Register all the desired applications 
hgs
parents:
diff changeset
   322
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
   323
    
hgs
parents:
diff changeset
   324
    //Start the tmserver device and its services
hgs
parents:
diff changeset
   325
    iTmServer->StartL();  
hgs
parents:
diff changeset
   326
    
hgs
parents:
diff changeset
   327
    //Start the control point and search for device
hgs
parents:
diff changeset
   328
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
   329
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
   330
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
   331
    CActiveScheduler::Start();
hgs
parents:
diff changeset
   332
 
hgs
parents:
diff changeset
   333
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
   334
        {
hgs
parents:
diff changeset
   335
         //Stop the tmserver device and its services
hgs
parents:
diff changeset
   336
         iTmServer->StopL(); 
hgs
parents:
diff changeset
   337
        }
hgs
parents:
diff changeset
   338
    
hgs
parents:
diff changeset
   339
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   340
    iTestTimer->After(15);
hgs
parents:
diff changeset
   341
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
   342
       
hgs
parents:
diff changeset
   343
    if ( iDeviceLostVerified )
hgs
parents:
diff changeset
   344
        {
hgs
parents:
diff changeset
   345
        _LIT( KDescription , "Terminalmode server Device stopped successfully");
hgs
parents:
diff changeset
   346
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   347
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   348
        }
hgs
parents:
diff changeset
   349
    else
hgs
parents:
diff changeset
   350
        {
hgs
parents:
diff changeset
   351
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   352
        _LIT( KDescription , "Stopping of Terminalmode server Device Failed");
hgs
parents:
diff changeset
   353
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   354
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   355
        }
hgs
parents:
diff changeset
   356
hgs
parents:
diff changeset
   357
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
   358
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
   359
    delete iTestTimer;
hgs
parents:
diff changeset
   360
    iTestTimer = NULL;
hgs
parents:
diff changeset
   361
    REComSession::FinalClose();
hgs
parents:
diff changeset
   362
    return KErrNone;
hgs
parents:
diff changeset
   363
    }
hgs
parents:
diff changeset
   364
hgs
parents:
diff changeset
   365
hgs
parents:
diff changeset
   366
TInt CTmServerTest::ReStartTmServerDeviceL ( TTestResult& aResult )
hgs
parents:
diff changeset
   367
    {
hgs
parents:
diff changeset
   368
   _LIT( KLogInfo, "ReStart Terminalmode server Device" );
hgs
parents:
diff changeset
   369
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   370
    
hgs
parents:
diff changeset
   371
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
   372
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   373
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   374
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo,*this );
hgs
parents:
diff changeset
   375
hgs
parents:
diff changeset
   376
    //Register all the desired applications 
hgs
parents:
diff changeset
   377
    RegisterApplicationsL(*iTmServer);    
hgs
parents:
diff changeset
   378
    //Start the tmserver device and its services
hgs
parents:
diff changeset
   379
    iTmServer->StartL();
hgs
parents:
diff changeset
   380
    //Stop the tmserver device and its services
hgs
parents:
diff changeset
   381
    iTmServer->StopL();
hgs
parents:
diff changeset
   382
    //Start the tmserver device and its services
hgs
parents:
diff changeset
   383
    iTmServer->StartL();
hgs
parents:
diff changeset
   384
    
hgs
parents:
diff changeset
   385
    //Start the control point and search for device
hgs
parents:
diff changeset
   386
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
   387
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   388
    iTestTimer->After(15);
hgs
parents:
diff changeset
   389
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
   390
    
hgs
parents:
diff changeset
   391
    if ( iDeviceVerified)
hgs
parents:
diff changeset
   392
        {
hgs
parents:
diff changeset
   393
        _LIT( KDescription , "Terminalmode server Device re-started successfully");
hgs
parents:
diff changeset
   394
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   395
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   396
        }
hgs
parents:
diff changeset
   397
    else
hgs
parents:
diff changeset
   398
        {
hgs
parents:
diff changeset
   399
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   400
        _LIT( KDescription , "Re-starting of Terminalmode server Device Failed");
hgs
parents:
diff changeset
   401
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   402
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   403
        }
hgs
parents:
diff changeset
   404
    
hgs
parents:
diff changeset
   405
    delete iTestTimer;
hgs
parents:
diff changeset
   406
    iTestTimer = NULL;
hgs
parents:
diff changeset
   407
    REComSession::FinalClose();
hgs
parents:
diff changeset
   408
    return KErrNone;
hgs
parents:
diff changeset
   409
    }    
hgs
parents:
diff changeset
   410
hgs
parents:
diff changeset
   411
hgs
parents:
diff changeset
   412
TInt CTmServerTest::RegisterDuplicateAppL(  TTestResult& aResult  )
hgs
parents:
diff changeset
   413
    {   
hgs
parents:
diff changeset
   414
    _LIT( KLogInfo, "Register Duplicate Application" );
hgs
parents:
diff changeset
   415
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   416
hgs
parents:
diff changeset
   417
    //Sets the information associated with the terminal mode server device    
hgs
parents:
diff changeset
   418
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   419
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   420
    
hgs
parents:
diff changeset
   421
    _LIT8(KAppDesc, "Bluetooth A2DP Audio Server");
hgs
parents:
diff changeset
   422
    iRemotableApp = CUpnpRemotableApp::NewL( KAppId2Value ,_L8("Bluetooth A2DP"));
hgs
parents:
diff changeset
   423
    iRemotableApp->SetAppDescriptionL(KAppDesc());
hgs
parents:
diff changeset
   424
       
hgs
parents:
diff changeset
   425
    CUpnpTmInfoElement& tmInfoElement = iRemotableApp->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
   426
    tmInfoElement.AddTmInfoElementL(_L8("protocolID"),_L8("BTA2DP"));
hgs
parents:
diff changeset
   427
    tmInfoElement.AddTmInfoElementL(_L8("direction"),_L8("out"));
hgs
parents:
diff changeset
   428
       
hgs
parents:
diff changeset
   429
    CUpnpTmInfoElement& tmInfoElement1 = iRemotableApp->CreateTmInfoElementL(CUpnpTmInfoElement::EAppInfo);
hgs
parents:
diff changeset
   430
    tmInfoElement1.AddTmInfoElementL(_L8("appCategory"),_L8("0x0000003"));
hgs
parents:
diff changeset
   431
    tmInfoElement1.AddTmInfoElementL(_L8("trustLevel"),_L8("0x00000001"));
hgs
parents:
diff changeset
   432
       
hgs
parents:
diff changeset
   433
    iRemotableApp->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathBtA2DpUnLaunched, KIconWidth2, KIconHeight2, KIconDepth1,KTestSvgMimeType)); 
hgs
parents:
diff changeset
   434
    iRemotableApp->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathBtA2DpLaunched,KIconWidth3, KIconHeight3, KIconDepth1,KTestSvgMimeType));
hgs
parents:
diff changeset
   435
    iRemotableApp->SetResourceStatusL(_L8("free"));
hgs
parents:
diff changeset
   436
hgs
parents:
diff changeset
   437
    // Register the application 
hgs
parents:
diff changeset
   438
    iTmServer->RegisterAppL(iRemotableApp);
hgs
parents:
diff changeset
   439
    
hgs
parents:
diff changeset
   440
    iRemotableApp1 = CUpnpRemotableApp::NewL( KAppId2Value ,_L8("Bluetooth A2DP"));
hgs
parents:
diff changeset
   441
    iRemotableApp1->SetAppDescriptionL(KAppDesc());
hgs
parents:
diff changeset
   442
          
hgs
parents:
diff changeset
   443
    CUpnpTmInfoElement& tmInfoElement2 = iRemotableApp1->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
   444
    tmInfoElement2.AddTmInfoElementL(_L8("protocolID"),_L8("BTA2DP"));
hgs
parents:
diff changeset
   445
    tmInfoElement2.AddTmInfoElementL(_L8("direction"),_L8("out"));
hgs
parents:
diff changeset
   446
          
hgs
parents:
diff changeset
   447
    CUpnpTmInfoElement& tmInfoElement3 = iRemotableApp1->CreateTmInfoElementL(CUpnpTmInfoElement::EAppInfo);
hgs
parents:
diff changeset
   448
    tmInfoElement3.AddTmInfoElementL(_L8("appCategory"),_L8("0x0000003"));
hgs
parents:
diff changeset
   449
    tmInfoElement3.AddTmInfoElementL(_L8("trustLevel"),_L8("0x00000001"));
hgs
parents:
diff changeset
   450
          
hgs
parents:
diff changeset
   451
    iRemotableApp1->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathBtA2DpUnLaunched, KIconWidth2, KIconHeight2, KIconDepth1,KTestSvgMimeType)); 
hgs
parents:
diff changeset
   452
    iRemotableApp1->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathBtA2DpLaunched,KIconWidth3, KIconHeight3, KIconDepth1,KTestSvgMimeType));
hgs
parents:
diff changeset
   453
    iRemotableApp1->SetResourceStatusL(_L8("free"));
hgs
parents:
diff changeset
   454
hgs
parents:
diff changeset
   455
    // Register the application which is already registered
hgs
parents:
diff changeset
   456
    iTmServer->RegisterAppL(iRemotableApp1);     
hgs
parents:
diff changeset
   457
    
hgs
parents:
diff changeset
   458
    _LIT( KDescription , "Registering of duplicate app is handled successfully");
hgs
parents:
diff changeset
   459
    aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   460
    iLog->Log( KDescription );
hgs
parents:
diff changeset
   461
    
hgs
parents:
diff changeset
   462
    delete iTmServer;
hgs
parents:
diff changeset
   463
    iTmServer = NULL;
hgs
parents:
diff changeset
   464
    
hgs
parents:
diff changeset
   465
    REComSession::FinalClose();
hgs
parents:
diff changeset
   466
    return KErrNone;
hgs
parents:
diff changeset
   467
    }
hgs
parents:
diff changeset
   468
hgs
parents:
diff changeset
   469
TInt CTmServerTest::RegisterDuplicateAppsL(  TTestResult& aResult  )
hgs
parents:
diff changeset
   470
    {   
hgs
parents:
diff changeset
   471
    _LIT( KLogInfo, "Register Duplicate Applications" );
hgs
parents:
diff changeset
   472
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   473
hgs
parents:
diff changeset
   474
    //Sets the information associated with the terminal mode server device    
hgs
parents:
diff changeset
   475
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   476
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   477
       
hgs
parents:
diff changeset
   478
    _LIT8(KAppDesc, "Mobile Navigation Application");
hgs
parents:
diff changeset
   479
    iRemotableApp = CUpnpRemotableApp::NewL( KAppIdValue ,_L8("Navigation"));  
hgs
parents:
diff changeset
   480
    iRemotableApp->SetAppDescriptionL(KAppDesc());
hgs
parents:
diff changeset
   481
    CUpnpTmInfoElement& tmInfoElement = iRemotableApp->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
   482
    tmInfoElement.AddTmInfoElementL(_L8("protocolID"),_L8("VNC"));
hgs
parents:
diff changeset
   483
    
hgs
parents:
diff changeset
   484
    CUpnpTmInfoElement& tmInfoElement1 = iRemotableApp->CreateTmInfoElementL(CUpnpTmInfoElement::EAppInfo);
hgs
parents:
diff changeset
   485
    tmInfoElement1.AddTmInfoElementL(_L8("appCategory"),_L8("0x00010001"));
hgs
parents:
diff changeset
   486
    tmInfoElement1.AddTmInfoElementL(_L8("trustLevel"),_L8("0x80"));
hgs
parents:
diff changeset
   487
    
hgs
parents:
diff changeset
   488
    CUpnpTmInfoElement& tmInfoElement2 = iRemotableApp->CreateTmInfoElementL(CUpnpTmInfoElement::EDisplayInfo);
hgs
parents:
diff changeset
   489
    tmInfoElement2.AddTmInfoElementL(_L8("contentCategory"),_L8("0x0000001"));
hgs
parents:
diff changeset
   490
    tmInfoElement2.AddTmInfoElementL(_L8("contentRules"),_L8("0x00000FE"));
hgs
parents:
diff changeset
   491
    tmInfoElement2.AddTmInfoElementL(_L8("trustLevel"),_L8("0x00000001"));
hgs
parents:
diff changeset
   492
    iRemotableApp->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathMaps, KIconWidth1, KIconHeight1, KIconDepth,KTestSvgMimeType));
hgs
parents:
diff changeset
   493
      
hgs
parents:
diff changeset
   494
    // Register the application 
hgs
parents:
diff changeset
   495
    iTmServer->RegisterAppL(iRemotableApp);
hgs
parents:
diff changeset
   496
    
hgs
parents:
diff changeset
   497
    _LIT8(KAppDesc1, "RTP Audio Server");
hgs
parents:
diff changeset
   498
    iRemotableApp1 = CUpnpRemotableApp::NewL( KAppId1Value ,_L8("RTP Server"));
hgs
parents:
diff changeset
   499
    iRemotableApp1->SetAppDescriptionL(KAppDesc1());
hgs
parents:
diff changeset
   500
     
hgs
parents:
diff changeset
   501
    CUpnpTmInfoElement& tmInfoElement3 = iRemotableApp1->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
   502
    tmInfoElement3.AddTmInfoElementL(_L8("protocolID"),_L8("RTP"));
hgs
parents:
diff changeset
   503
    tmInfoElement3.AddTmInfoElementL(_L8("format"),_L8("99"));
hgs
parents:
diff changeset
   504
    tmInfoElement3.AddTmInfoElementL(_L8("direction"),_L8("out"));
hgs
parents:
diff changeset
   505
       
hgs
parents:
diff changeset
   506
    CUpnpTmInfoElement& tmInfoElement4 = iRemotableApp1->CreateTmInfoElementL(CUpnpTmInfoElement::EAppInfo);
hgs
parents:
diff changeset
   507
    tmInfoElement4.AddTmInfoElementL(_L8("appCategory"),_L8("0x0000002"));
hgs
parents:
diff changeset
   508
    tmInfoElement4.AddTmInfoElementL(_L8("trustLevel"),_L8("0x00000001"));
hgs
parents:
diff changeset
   509
       
hgs
parents:
diff changeset
   510
    CUpnpTmInfoElement& tmInfoElement5 = iRemotableApp1->CreateTmInfoElementL(CUpnpTmInfoElement::EAudioInfo);
hgs
parents:
diff changeset
   511
    tmInfoElement5.AddTmInfoElementL(_L8("audioType"),_L8("all"));    
hgs
parents:
diff changeset
   512
    iRemotableApp1->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathMusicUnLaunched,KIconWidth, KIconHeight, KIconDepth,KTestSvgMimeType));
hgs
parents:
diff changeset
   513
    iRemotableApp1->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathMusicLaunched,KIconWidth, KIconHeight, KIconDepth,KTestSvgMimeType));
hgs
parents:
diff changeset
   514
    iRemotableApp1->SetResourceStatusL(_L8("free"));
hgs
parents:
diff changeset
   515
     
hgs
parents:
diff changeset
   516
    iRemotableAppArray.AppendL(iRemotableApp1);     
hgs
parents:
diff changeset
   517
   
hgs
parents:
diff changeset
   518
    iRemotableApp2 = CUpnpRemotableApp::NewL( KAppId1Value ,_L8("RTP Server"));
hgs
parents:
diff changeset
   519
    iRemotableApp2->SetAppDescriptionL(KAppDesc1());
hgs
parents:
diff changeset
   520
        
hgs
parents:
diff changeset
   521
    CUpnpTmInfoElement& tmInfoElement6 = iRemotableApp2->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
   522
    tmInfoElement6.AddTmInfoElementL(_L8("protocolID"),_L8("RTP"));
hgs
parents:
diff changeset
   523
    tmInfoElement6.AddTmInfoElementL(_L8("format"),_L8("99"));
hgs
parents:
diff changeset
   524
    tmInfoElement6.AddTmInfoElementL(_L8("direction"),_L8("out"));
hgs
parents:
diff changeset
   525
          
hgs
parents:
diff changeset
   526
    CUpnpTmInfoElement& tmInfoElement7 = iRemotableApp2->CreateTmInfoElementL(CUpnpTmInfoElement::EAppInfo);
hgs
parents:
diff changeset
   527
    tmInfoElement7.AddTmInfoElementL(_L8("appCategory"),_L8("0x0000002"));
hgs
parents:
diff changeset
   528
    tmInfoElement7.AddTmInfoElementL(_L8("trustLevel"),_L8("0x00000001"));
hgs
parents:
diff changeset
   529
          
hgs
parents:
diff changeset
   530
    CUpnpTmInfoElement& tmInfoElement8 = iRemotableApp2->CreateTmInfoElementL(CUpnpTmInfoElement::EAudioInfo);
hgs
parents:
diff changeset
   531
    tmInfoElement8.AddTmInfoElementL(_L8("audioType"),_L8("all"));    
hgs
parents:
diff changeset
   532
    iRemotableApp2->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathMusicUnLaunched,KIconWidth, KIconHeight, KIconDepth,KTestSvgMimeType));
hgs
parents:
diff changeset
   533
    iRemotableApp2->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathMusicLaunched,KIconWidth, KIconHeight, KIconDepth,KTestSvgMimeType));
hgs
parents:
diff changeset
   534
    iRemotableApp2->SetResourceStatusL(_L8("free"));
hgs
parents:
diff changeset
   535
    iRemotableAppArray.AppendL(iRemotableApp2);     
hgs
parents:
diff changeset
   536
hgs
parents:
diff changeset
   537
    // Register the dulplicate applications
hgs
parents:
diff changeset
   538
    iTmServer->RegisterAppsL( iRemotableAppArray);     
hgs
parents:
diff changeset
   539
    
hgs
parents:
diff changeset
   540
    _LIT( KDescription , "Registering of duplicate applications is handled successfully");
hgs
parents:
diff changeset
   541
    aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   542
    iLog->Log( KDescription );
hgs
parents:
diff changeset
   543
    iRemotableAppArray.Close();
hgs
parents:
diff changeset
   544
    delete iTmServer;
hgs
parents:
diff changeset
   545
    iTmServer = NULL;
hgs
parents:
diff changeset
   546
    
hgs
parents:
diff changeset
   547
    REComSession::FinalClose();
hgs
parents:
diff changeset
   548
    return KErrNone;
hgs
parents:
diff changeset
   549
    }
hgs
parents:
diff changeset
   550
hgs
parents:
diff changeset
   551
hgs
parents:
diff changeset
   552
TInt CTmServerTest::UnRegisterAppL(  TTestResult& aResult  )
hgs
parents:
diff changeset
   553
    {
hgs
parents:
diff changeset
   554
    _LIT( KLogInfo, "UnRegister Application" );
hgs
parents:
diff changeset
   555
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   556
hgs
parents:
diff changeset
   557
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   558
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   559
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   560
hgs
parents:
diff changeset
   561
    //Register all the desired applications 
hgs
parents:
diff changeset
   562
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
   563
    
hgs
parents:
diff changeset
   564
    //Unregister the application by specifying AppId 
hgs
parents:
diff changeset
   565
    iTmServer->UnRegisterApp( KAppIdValue );
hgs
parents:
diff changeset
   566
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   567
    iTestTimer->After(15);
hgs
parents:
diff changeset
   568
    CActiveScheduler::Start();
hgs
parents:
diff changeset
   569
    
hgs
parents:
diff changeset
   570
    _LIT( KDescription , "Application is un-registered successfully");
hgs
parents:
diff changeset
   571
    aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   572
    iLog->Log( KDescription );
hgs
parents:
diff changeset
   573
    
hgs
parents:
diff changeset
   574
    delete iTestTimer;
hgs
parents:
diff changeset
   575
    iTestTimer = NULL;
hgs
parents:
diff changeset
   576
    
hgs
parents:
diff changeset
   577
    REComSession::FinalClose();
hgs
parents:
diff changeset
   578
    return KErrNone;
hgs
parents:
diff changeset
   579
    }
hgs
parents:
diff changeset
   580
hgs
parents:
diff changeset
   581
TInt CTmServerTest::UnRegisterAppsL(  TTestResult& aResult  )
hgs
parents:
diff changeset
   582
    {
hgs
parents:
diff changeset
   583
    _LIT( KLogInfo, "UnRegister Multiple Applications" );
hgs
parents:
diff changeset
   584
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   585
    
hgs
parents:
diff changeset
   586
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   587
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   588
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   589
   
hgs
parents:
diff changeset
   590
    //Register all the desired applications 
hgs
parents:
diff changeset
   591
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
   592
    
hgs
parents:
diff changeset
   593
    RArray<TUint> appIdArray;
hgs
parents:
diff changeset
   594
    appIdArray.AppendL( KAppId1Value );
hgs
parents:
diff changeset
   595
    appIdArray.AppendL( KAppId2Value );
hgs
parents:
diff changeset
   596
hgs
parents:
diff changeset
   597
    //Unregister multiple applications by specifying array of AppIds  
hgs
parents:
diff changeset
   598
    iTmServer->UnRegisterApps( appIdArray); 
hgs
parents:
diff changeset
   599
hgs
parents:
diff changeset
   600
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   601
    iTestTimer->After(15);
hgs
parents:
diff changeset
   602
    CActiveScheduler::Start();
hgs
parents:
diff changeset
   603
    
hgs
parents:
diff changeset
   604
    _LIT( KDescription , "Multiple Applications are un-registered successfully");
hgs
parents:
diff changeset
   605
    aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   606
    iLog->Log( KDescription );
hgs
parents:
diff changeset
   607
    appIdArray.Close();
hgs
parents:
diff changeset
   608
    
hgs
parents:
diff changeset
   609
    delete iTestTimer;
hgs
parents:
diff changeset
   610
    iTestTimer = NULL;     
hgs
parents:
diff changeset
   611
    REComSession::FinalClose();
hgs
parents:
diff changeset
   612
    return KErrNone;
hgs
parents:
diff changeset
   613
    }
hgs
parents:
diff changeset
   614
hgs
parents:
diff changeset
   615
TInt CTmServerTest::UnRegisterUnRegisteredAppL(  TTestResult& aResult  )
hgs
parents:
diff changeset
   616
    {
hgs
parents:
diff changeset
   617
    _LIT( KLogInfo, "UnRegister UnRegistered Application" );
hgs
parents:
diff changeset
   618
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   619
    
hgs
parents:
diff changeset
   620
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   621
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   622
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   623
hgs
parents:
diff changeset
   624
    //Register all the desired applications 
hgs
parents:
diff changeset
   625
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
   626
    
hgs
parents:
diff changeset
   627
    //Unregister the application which is already unregistered
hgs
parents:
diff changeset
   628
    iTmServer->UnRegisterApp( KNonExistentAppIdValue );
hgs
parents:
diff changeset
   629
    
hgs
parents:
diff changeset
   630
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   631
    iTestTimer->After(15);
hgs
parents:
diff changeset
   632
    CActiveScheduler::Start();
hgs
parents:
diff changeset
   633
    
hgs
parents:
diff changeset
   634
    _LIT( KDescription , "UnRegistering of UnRegistered Application is handled successfully");
hgs
parents:
diff changeset
   635
    aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   636
    iLog->Log( KDescription );
hgs
parents:
diff changeset
   637
    
hgs
parents:
diff changeset
   638
    delete iTestTimer;
hgs
parents:
diff changeset
   639
    iTestTimer = NULL;
hgs
parents:
diff changeset
   640
    
hgs
parents:
diff changeset
   641
    REComSession::FinalClose();
hgs
parents:
diff changeset
   642
    return KErrNone;
hgs
parents:
diff changeset
   643
    }
hgs
parents:
diff changeset
   644
hgs
parents:
diff changeset
   645
TInt CTmServerTest::UnRegisterUnRegisteredAppsL(  TTestResult& aResult  )
hgs
parents:
diff changeset
   646
    {
hgs
parents:
diff changeset
   647
    _LIT( KLogInfo, "UnRegister Multiple UnRegistered Applications" );
hgs
parents:
diff changeset
   648
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   649
    
hgs
parents:
diff changeset
   650
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   651
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   652
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   653
hgs
parents:
diff changeset
   654
    //Register all the desired applications 
hgs
parents:
diff changeset
   655
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
   656
    
hgs
parents:
diff changeset
   657
    RArray<TUint> appIdArray;
hgs
parents:
diff changeset
   658
    appIdArray.AppendL( KNonExistentAppIdValue );
hgs
parents:
diff changeset
   659
    appIdArray.AppendL( KNonExistentAppId1Value );
hgs
parents:
diff changeset
   660
hgs
parents:
diff changeset
   661
    //Unregister multiple applications which are already unregistered
hgs
parents:
diff changeset
   662
    iTmServer->UnRegisterApps( appIdArray);
hgs
parents:
diff changeset
   663
        
hgs
parents:
diff changeset
   664
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   665
    iTestTimer->After(15);
hgs
parents:
diff changeset
   666
    CActiveScheduler::Start();
hgs
parents:
diff changeset
   667
    
hgs
parents:
diff changeset
   668
    _LIT( KDescription , "UnRegistering of UnRegistered Applications is handled successfully");
hgs
parents:
diff changeset
   669
    aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   670
    iLog->Log( KDescription );
hgs
parents:
diff changeset
   671
    
hgs
parents:
diff changeset
   672
    appIdArray.Close();
hgs
parents:
diff changeset
   673
    delete iTestTimer;
hgs
parents:
diff changeset
   674
    iTestTimer = NULL;
hgs
parents:
diff changeset
   675
    
hgs
parents:
diff changeset
   676
    REComSession::FinalClose();
hgs
parents:
diff changeset
   677
    return KErrNone;
hgs
parents:
diff changeset
   678
    }
hgs
parents:
diff changeset
   679
hgs
parents:
diff changeset
   680
TInt CTmServerTest::HandleEventDuplicateAppStatusUpdateL( TTestResult& aResult )
hgs
parents:
diff changeset
   681
 {
hgs
parents:
diff changeset
   682
    _LIT( KLogInfo, "Handle Event For Duplicate AppStatus Update" );
hgs
parents:
diff changeset
   683
    iLog->Log( KLogInfo ); 
hgs
parents:
diff changeset
   684
          
hgs
parents:
diff changeset
   685
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
   686
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   687
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   688
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   689
hgs
parents:
diff changeset
   690
    //Register all the desired applications 
hgs
parents:
diff changeset
   691
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
   692
       
hgs
parents:
diff changeset
   693
    //Start the tmserver device and its services              
hgs
parents:
diff changeset
   694
    iTmServer ->StartL();
hgs
parents:
diff changeset
   695
    //Start the control point and search for device
hgs
parents:
diff changeset
   696
    iSearchDevice = CDiscoverDevice::NewL(*this);          
hgs
parents:
diff changeset
   697
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
   698
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
   699
    CActiveScheduler::Start();     
hgs
parents:
diff changeset
   700
          
hgs
parents:
diff changeset
   701
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
   702
         { 
hgs
parents:
diff changeset
   703
             //Subscribe to Services
hgs
parents:
diff changeset
   704
           iSearchDevice->SubscribeToServiceL();         
hgs
parents:
diff changeset
   705
          }  
hgs
parents:
diff changeset
   706
  
hgs
parents:
diff changeset
   707
    RArray<TUint> updatedAppIdList;
hgs
parents:
diff changeset
   708
    updatedAppIdList.Append(KAppId1Value);
hgs
parents:
diff changeset
   709
    updatedAppIdList.Append(KAppId1Value);
hgs
parents:
diff changeset
   710
    //Update the status of applications which have undergone some change
hgs
parents:
diff changeset
   711
    iTmServer->UpdateAppStatusL(updatedAppIdList); 
hgs
parents:
diff changeset
   712
       
hgs
parents:
diff changeset
   713
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   714
    iTestTimer->After(15);
hgs
parents:
diff changeset
   715
    CActiveScheduler::Start();
hgs
parents:
diff changeset
   716
       
hgs
parents:
diff changeset
   717
    if ( iStatusNotified )
hgs
parents:
diff changeset
   718
         {
hgs
parents:
diff changeset
   719
          _LIT( KDescription , "Handle Event For Duplicate AppStatus Update handled successfully");
hgs
parents:
diff changeset
   720
          aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   721
          iLog->Log( KDescription );
hgs
parents:
diff changeset
   722
         }
hgs
parents:
diff changeset
   723
    else
hgs
parents:
diff changeset
   724
         {
hgs
parents:
diff changeset
   725
          aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   726
          _LIT( KDescription , "Handle Event For Duplicate AppStatus Update handling Failed");
hgs
parents:
diff changeset
   727
          aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   728
          iLog->Log( KDescription );
hgs
parents:
diff changeset
   729
         }
hgs
parents:
diff changeset
   730
    updatedAppIdList.Close();  
hgs
parents:
diff changeset
   731
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
   732
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
   733
    delete iTestTimer;
hgs
parents:
diff changeset
   734
    iTestTimer = NULL;
hgs
parents:
diff changeset
   735
    REComSession::FinalClose();
hgs
parents:
diff changeset
   736
    return KErrNone;
hgs
parents:
diff changeset
   737
  }
hgs
parents:
diff changeset
   738
hgs
parents:
diff changeset
   739
TInt CTmServerTest::HandleEventProfileIdListStatusUpdateL( TTestResult& aResult )
hgs
parents:
diff changeset
   740
 {
hgs
parents:
diff changeset
   741
    _LIT( KLogInfo, "Handle Event For ProfileIdList Status Update" );
hgs
parents:
diff changeset
   742
    iLog->Log( KLogInfo ); 
hgs
parents:
diff changeset
   743
    
hgs
parents:
diff changeset
   744
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
   745
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   746
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   747
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   748
hgs
parents:
diff changeset
   749
    //Register all the desired applications
hgs
parents:
diff changeset
   750
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
   751
    
hgs
parents:
diff changeset
   752
    //Start the tmserver device and its services
hgs
parents:
diff changeset
   753
    iTmServer ->StartL();
hgs
parents:
diff changeset
   754
    //Start the control point and search for device
hgs
parents:
diff changeset
   755
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
   756
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
   757
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
   758
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
   759
    
hgs
parents:
diff changeset
   760
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
   761
        {
hgs
parents:
diff changeset
   762
        //Subscribes to a service 
hgs
parents:
diff changeset
   763
        iSearchDevice->SubscribeToServiceL();
hgs
parents:
diff changeset
   764
        }  
hgs
parents:
diff changeset
   765
hgs
parents:
diff changeset
   766
    RArray<TUint> UnusedProfileIdList;
hgs
parents:
diff changeset
   767
    UnusedProfileIdList.Append(5);
hgs
parents:
diff changeset
   768
    UnusedProfileIdList.Append(6);
hgs
parents:
diff changeset
   769
    //Update the list of profile IDs for profiles which are not used
hgs
parents:
diff changeset
   770
    iTmServer->UpdateUnusedProfileIdsL(UnusedProfileIdList);  
hgs
parents:
diff changeset
   771
    
hgs
parents:
diff changeset
   772
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   773
    iTestTimer->After(15);
hgs
parents:
diff changeset
   774
    CActiveScheduler::Start();
hgs
parents:
diff changeset
   775
hgs
parents:
diff changeset
   776
    if ( iStatusNotified )
hgs
parents:
diff changeset
   777
        {
hgs
parents:
diff changeset
   778
        _LIT( KDescription , "Handle Event For ProfileIdList Status Update handled successfully");
hgs
parents:
diff changeset
   779
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   780
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   781
        }
hgs
parents:
diff changeset
   782
    else
hgs
parents:
diff changeset
   783
        {
hgs
parents:
diff changeset
   784
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   785
        _LIT( KDescription , "Handle Event For ProfileIdList Status Update handling failed");
hgs
parents:
diff changeset
   786
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   787
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   788
        }
hgs
parents:
diff changeset
   789
    
hgs
parents:
diff changeset
   790
       UnusedProfileIdList.Close();
hgs
parents:
diff changeset
   791
       delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
   792
       iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
   793
       delete iTestTimer;
hgs
parents:
diff changeset
   794
       iTestTimer = NULL;
hgs
parents:
diff changeset
   795
       REComSession::FinalClose();
hgs
parents:
diff changeset
   796
       return KErrNone;
hgs
parents:
diff changeset
   797
}
hgs
parents:
diff changeset
   798
hgs
parents:
diff changeset
   799
TInt CTmServerTest::HandleLaunchAppActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
   800
    {
hgs
parents:
diff changeset
   801
    _LIT( KLogInfo, "Handle LaunchApp Command" );
hgs
parents:
diff changeset
   802
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   803
    
hgs
parents:
diff changeset
   804
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
   805
hgs
parents:
diff changeset
   806
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   807
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   808
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   809
   
hgs
parents:
diff changeset
   810
    //Register all the desired applications
hgs
parents:
diff changeset
   811
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
   812
hgs
parents:
diff changeset
   813
    //Start the tmserver device and its services
hgs
parents:
diff changeset
   814
    iTmServer ->StartL();
hgs
parents:
diff changeset
   815
    //Start the control point and search for device
hgs
parents:
diff changeset
   816
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
   817
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
   818
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
   819
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
   820
hgs
parents:
diff changeset
   821
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
   822
        {
hgs
parents:
diff changeset
   823
         //Launch the application remotely by specifying appId and profileId 
hgs
parents:
diff changeset
   824
         iSearchDevice->LaunchAppActionL(KAppId1Value,KProfileIdValue);
hgs
parents:
diff changeset
   825
        }   
hgs
parents:
diff changeset
   826
    
hgs
parents:
diff changeset
   827
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   828
    iTestTimer->After(15);
hgs
parents:
diff changeset
   829
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
   830
hgs
parents:
diff changeset
   831
    if (iStartApp )
hgs
parents:
diff changeset
   832
        {
hgs
parents:
diff changeset
   833
        _LIT( KDescription , "LaunchApp Command handled successfully");
hgs
parents:
diff changeset
   834
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   835
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   836
        }
hgs
parents:
diff changeset
   837
    else
hgs
parents:
diff changeset
   838
        {
hgs
parents:
diff changeset
   839
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   840
        _LIT( KDescription , "LaunchApp Command handled  Failed");
hgs
parents:
diff changeset
   841
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   842
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   843
        }
hgs
parents:
diff changeset
   844
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
   845
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
   846
    delete iTestTimer;
hgs
parents:
diff changeset
   847
    iTestTimer = NULL;
hgs
parents:
diff changeset
   848
    REComSession::FinalClose();
hgs
parents:
diff changeset
   849
    return KErrNone;
hgs
parents:
diff changeset
   850
    }
hgs
parents:
diff changeset
   851
hgs
parents:
diff changeset
   852
TInt CTmServerTest::HandleTerminateAppActionL( TTestResult& aResult )
hgs
parents:
diff changeset
   853
    {
hgs
parents:
diff changeset
   854
    _LIT( KLogInfo, "Handle TerminateApp Command" );
hgs
parents:
diff changeset
   855
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
   856
    
hgs
parents:
diff changeset
   857
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
   858
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   859
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   860
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   861
hgs
parents:
diff changeset
   862
    //Register all the desired applications
hgs
parents:
diff changeset
   863
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
   864
hgs
parents:
diff changeset
   865
    //Start the tmserver device and its services
hgs
parents:
diff changeset
   866
    iTmServer->StartL();
hgs
parents:
diff changeset
   867
hgs
parents:
diff changeset
   868
    //Start the control point and search for device
hgs
parents:
diff changeset
   869
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
   870
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
   871
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
   872
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
   873
    
hgs
parents:
diff changeset
   874
    if ( iDeviceVerified )
hgs
parents:
diff changeset
   875
        {
hgs
parents:
diff changeset
   876
        //Terminate the application which is already running
hgs
parents:
diff changeset
   877
        iSearchDevice->TerminateAppActionL( KAppId1Value,KProfileIdValue);
hgs
parents:
diff changeset
   878
        }
hgs
parents:
diff changeset
   879
    
hgs
parents:
diff changeset
   880
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   881
    iTestTimer->After(15);
hgs
parents:
diff changeset
   882
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
   883
    
hgs
parents:
diff changeset
   884
    if ( iStopApp)
hgs
parents:
diff changeset
   885
        {
hgs
parents:
diff changeset
   886
        _LIT( KDescription , "TerminateApp Command handled successfully");
hgs
parents:
diff changeset
   887
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   888
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   889
        }
hgs
parents:
diff changeset
   890
    else
hgs
parents:
diff changeset
   891
        {
hgs
parents:
diff changeset
   892
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   893
        _LIT( KDescription , "TerminateApp Command handling Failed");
hgs
parents:
diff changeset
   894
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   895
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   896
        }
hgs
parents:
diff changeset
   897
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
   898
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
   899
    delete iTestTimer;
hgs
parents:
diff changeset
   900
    iTestTimer = NULL;
hgs
parents:
diff changeset
   901
    REComSession::FinalClose();
hgs
parents:
diff changeset
   902
    return KErrNone;
hgs
parents:
diff changeset
   903
    }
hgs
parents:
diff changeset
   904
hgs
parents:
diff changeset
   905
TInt CTmServerTest::HandleInvalidAppIdLaunchAppActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
   906
    {
hgs
parents:
diff changeset
   907
    _LIT( KLogInfo, "Handle Invalid AppId LaunchApp Command" );
hgs
parents:
diff changeset
   908
    iLog->Log( KLogInfo );    
hgs
parents:
diff changeset
   909
    
hgs
parents:
diff changeset
   910
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
   911
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   912
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   913
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   914
hgs
parents:
diff changeset
   915
    //Register all the desired applications
hgs
parents:
diff changeset
   916
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
   917
    
hgs
parents:
diff changeset
   918
    //Start the tmserver device and its services
hgs
parents:
diff changeset
   919
    iTmServer->StartL();
hgs
parents:
diff changeset
   920
    //Start the control point and search for device
hgs
parents:
diff changeset
   921
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
   922
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
   923
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
   924
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
   925
    
hgs
parents:
diff changeset
   926
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
   927
        {
hgs
parents:
diff changeset
   928
        //Launch the application by specifying invalid appId
hgs
parents:
diff changeset
   929
        iSearchDevice->LaunchAppActionL( KInvalidAppIdValue,KProfileIdValue);
hgs
parents:
diff changeset
   930
        }   
hgs
parents:
diff changeset
   931
    
hgs
parents:
diff changeset
   932
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   933
    iTestTimer->After(15);
hgs
parents:
diff changeset
   934
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
   935
hgs
parents:
diff changeset
   936
    if (iStartApp )
hgs
parents:
diff changeset
   937
        {
hgs
parents:
diff changeset
   938
        _LIT( KDescription , "LaunchApp Command with invalid AppId handled successfully");
hgs
parents:
diff changeset
   939
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   940
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   941
        }
hgs
parents:
diff changeset
   942
    else
hgs
parents:
diff changeset
   943
        {
hgs
parents:
diff changeset
   944
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   945
        _LIT( KDescription , "LaunchApp Command with invalid AppId handling Failed");
hgs
parents:
diff changeset
   946
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   947
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   948
        }
hgs
parents:
diff changeset
   949
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
   950
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
   951
    delete iTestTimer;
hgs
parents:
diff changeset
   952
    iTestTimer = NULL;
hgs
parents:
diff changeset
   953
    REComSession::FinalClose();
hgs
parents:
diff changeset
   954
    return KErrNone;
hgs
parents:
diff changeset
   955
    }
hgs
parents:
diff changeset
   956
hgs
parents:
diff changeset
   957
TInt CTmServerTest::HandleInvalidProfileIdLaunchAppActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
   958
    {
hgs
parents:
diff changeset
   959
    _LIT( KLogInfo, "Handle Invalid ProfileId LaunchApp Command" );
hgs
parents:
diff changeset
   960
    iLog->Log( KLogInfo );    
hgs
parents:
diff changeset
   961
    
hgs
parents:
diff changeset
   962
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
   963
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
   964
    SetTmServerSettingsL();
hgs
parents:
diff changeset
   965
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
   966
    //Register all the desired applications
hgs
parents:
diff changeset
   967
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
   968
    //Start the tmserver device and its services
hgs
parents:
diff changeset
   969
    iTmServer->StartL();
hgs
parents:
diff changeset
   970
hgs
parents:
diff changeset
   971
    //Start the control point and search for device
hgs
parents:
diff changeset
   972
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
   973
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
   974
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
   975
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
   976
    
hgs
parents:
diff changeset
   977
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
   978
        {
hgs
parents:
diff changeset
   979
        //Launch the application by specifying invalid profileId
hgs
parents:
diff changeset
   980
        iSearchDevice->LaunchAppActionL( KAppId1Value,KInvalidProfileIdValue);
hgs
parents:
diff changeset
   981
        }   
hgs
parents:
diff changeset
   982
    
hgs
parents:
diff changeset
   983
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
   984
    iTestTimer->After(15);
hgs
parents:
diff changeset
   985
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
   986
    if (iStartApp )
hgs
parents:
diff changeset
   987
        {
hgs
parents:
diff changeset
   988
        _LIT( KDescription , "LaunchApp Command with invalid ProfileId handled successfully");
hgs
parents:
diff changeset
   989
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   990
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   991
        }
hgs
parents:
diff changeset
   992
    else
hgs
parents:
diff changeset
   993
        {
hgs
parents:
diff changeset
   994
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
   995
        _LIT( KDescription , "LaunchApp Command with invalid ProfileId handling Failed");
hgs
parents:
diff changeset
   996
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
   997
        iLog->Log( KDescription );
hgs
parents:
diff changeset
   998
        }
hgs
parents:
diff changeset
   999
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1000
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1001
    delete iTestTimer;
hgs
parents:
diff changeset
  1002
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1003
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1004
    return KErrNone;
hgs
parents:
diff changeset
  1005
    }
hgs
parents:
diff changeset
  1006
hgs
parents:
diff changeset
  1007
TInt CTmServerTest::HandleNonExistentLaunchAppActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  1008
    {
hgs
parents:
diff changeset
  1009
    _LIT( KLogInfo, "Handle LaunchApp Command For Non-Existent AppID" );
hgs
parents:
diff changeset
  1010
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1011
    
hgs
parents:
diff changeset
  1012
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1013
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1014
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1015
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1016
hgs
parents:
diff changeset
  1017
    //Register all the desired applications
hgs
parents:
diff changeset
  1018
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
  1019
hgs
parents:
diff changeset
  1020
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1021
    iTmServer->StartL();  
hgs
parents:
diff changeset
  1022
    
hgs
parents:
diff changeset
  1023
    //Start the control point and search for device
hgs
parents:
diff changeset
  1024
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1025
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1026
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1027
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1028
hgs
parents:
diff changeset
  1029
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1030
        {
hgs
parents:
diff changeset
  1031
        //Launch the application by specifying non-existent appId
hgs
parents:
diff changeset
  1032
        iSearchDevice->LaunchAppActionL( KNonExistentAppIdValue, KProfileIdValue );
hgs
parents:
diff changeset
  1033
        }   
hgs
parents:
diff changeset
  1034
    
hgs
parents:
diff changeset
  1035
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1036
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1037
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1038
hgs
parents:
diff changeset
  1039
    if (iStartApp )
hgs
parents:
diff changeset
  1040
        {
hgs
parents:
diff changeset
  1041
        _LIT( KDescription , "LaunchApp Command For Non-Existent AppID handled successfully");
hgs
parents:
diff changeset
  1042
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1043
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1044
        }
hgs
parents:
diff changeset
  1045
    else
hgs
parents:
diff changeset
  1046
        {
hgs
parents:
diff changeset
  1047
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1048
        _LIT( KDescription , "LaunchApp Command For Non-Existent AppID handled  Failed");
hgs
parents:
diff changeset
  1049
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1050
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1051
        }
hgs
parents:
diff changeset
  1052
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1053
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1054
    delete iTestTimer;
hgs
parents:
diff changeset
  1055
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1056
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1057
    return KErrNone;
hgs
parents:
diff changeset
  1058
    }
hgs
parents:
diff changeset
  1059
hgs
parents:
diff changeset
  1060
TInt CTmServerTest::HandleUnauthorizedLaunchAppActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  1061
    {
hgs
parents:
diff changeset
  1062
    _LIT( KLogInfo, "Handle LaunchApp Command For UnAuthorized AppID" );
hgs
parents:
diff changeset
  1063
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1064
    
hgs
parents:
diff changeset
  1065
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1066
    
hgs
parents:
diff changeset
  1067
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1068
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1069
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1070
hgs
parents:
diff changeset
  1071
    //Register all the desired applications
hgs
parents:
diff changeset
  1072
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
  1073
    
hgs
parents:
diff changeset
  1074
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1075
    iTmServer ->StartL();
hgs
parents:
diff changeset
  1076
hgs
parents:
diff changeset
  1077
    //Start the control point and search for device
hgs
parents:
diff changeset
  1078
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1079
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1080
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1081
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1082
hgs
parents:
diff changeset
  1083
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1084
        {
hgs
parents:
diff changeset
  1085
         //Launch the application by specifying unauthorized appId
hgs
parents:
diff changeset
  1086
         iSearchDevice->LaunchAppActionL(KAppId5Value,KProfileIdValue);
hgs
parents:
diff changeset
  1087
        }   
hgs
parents:
diff changeset
  1088
    
hgs
parents:
diff changeset
  1089
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1090
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1091
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1092
    if (iStartApp )
hgs
parents:
diff changeset
  1093
        {
hgs
parents:
diff changeset
  1094
       _LIT( KDescription , "LaunchApp Command For UnAuthorized AppID handled successfully");
hgs
parents:
diff changeset
  1095
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1096
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1097
        }
hgs
parents:
diff changeset
  1098
    else
hgs
parents:
diff changeset
  1099
        {
hgs
parents:
diff changeset
  1100
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1101
        _LIT( KDescription , "LaunchApp Command For UnAuthorized AppID handled  Failed");
hgs
parents:
diff changeset
  1102
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1103
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1104
        }
hgs
parents:
diff changeset
  1105
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1106
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1107
    delete iTestTimer;
hgs
parents:
diff changeset
  1108
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1109
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1110
    return KErrNone;
hgs
parents:
diff changeset
  1111
    }
hgs
parents:
diff changeset
  1112
hgs
parents:
diff changeset
  1113
TInt CTmServerTest::HandleDeviceLockedLaunchAppActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  1114
    {
hgs
parents:
diff changeset
  1115
    _LIT( KLogInfo, "Handle Device Locked Condition For LaunchApp Command" );
hgs
parents:
diff changeset
  1116
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1117
    
hgs
parents:
diff changeset
  1118
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1119
    
hgs
parents:
diff changeset
  1120
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1121
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1122
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1123
hgs
parents:
diff changeset
  1124
    //Register all the desired applications
hgs
parents:
diff changeset
  1125
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
  1126
    
hgs
parents:
diff changeset
  1127
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1128
    iTmServer ->StartL();
hgs
parents:
diff changeset
  1129
hgs
parents:
diff changeset
  1130
    //Start the control point and search for device
hgs
parents:
diff changeset
  1131
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1132
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1133
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1134
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1135
hgs
parents:
diff changeset
  1136
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1137
        {
hgs
parents:
diff changeset
  1138
         //Launch the application
hgs
parents:
diff changeset
  1139
         iSearchDevice->LaunchAppActionL(KAppId4Value,KProfileIdValue);
hgs
parents:
diff changeset
  1140
        }   
hgs
parents:
diff changeset
  1141
    
hgs
parents:
diff changeset
  1142
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1143
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1144
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1145
    if (iStartApp )
hgs
parents:
diff changeset
  1146
        {
hgs
parents:
diff changeset
  1147
       _LIT( KDescription , "LaunchApp Command For Device Locked Condition handled successfully");
hgs
parents:
diff changeset
  1148
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1149
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1150
        }
hgs
parents:
diff changeset
  1151
    else
hgs
parents:
diff changeset
  1152
        {
hgs
parents:
diff changeset
  1153
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1154
        _LIT( KDescription , "LaunchApp Command For Device Locked Condition handling Failed");
hgs
parents:
diff changeset
  1155
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1156
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1157
        }
hgs
parents:
diff changeset
  1158
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1159
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1160
    delete iTestTimer;
hgs
parents:
diff changeset
  1161
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1162
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1163
    return KErrNone;
hgs
parents:
diff changeset
  1164
    }
hgs
parents:
diff changeset
  1165
hgs
parents:
diff changeset
  1166
TInt CTmServerTest::HandleNonExistentTerminateAppActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  1167
    {
hgs
parents:
diff changeset
  1168
    _LIT( KLogInfo, "Handle TerminateApp Command For Non-Existent AppID" );
hgs
parents:
diff changeset
  1169
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1170
    
hgs
parents:
diff changeset
  1171
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1172
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1173
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1174
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1175
hgs
parents:
diff changeset
  1176
    //Register all the desired applications
hgs
parents:
diff changeset
  1177
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
  1178
    
hgs
parents:
diff changeset
  1179
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1180
    iTmServer->StartL();    
hgs
parents:
diff changeset
  1181
hgs
parents:
diff changeset
  1182
    //Start the control point and search for device
hgs
parents:
diff changeset
  1183
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1184
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1185
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1186
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1187
    
hgs
parents:
diff changeset
  1188
    if ( iDeviceVerified )
hgs
parents:
diff changeset
  1189
        {
hgs
parents:
diff changeset
  1190
         //Terminate the application by specifying unauthorized appId
hgs
parents:
diff changeset
  1191
         iSearchDevice->TerminateAppActionL( KNonExistentAppIdValue,KProfileIdValue );
hgs
parents:
diff changeset
  1192
        }
hgs
parents:
diff changeset
  1193
    
hgs
parents:
diff changeset
  1194
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1195
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1196
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  1197
    if ( iStopApp)
hgs
parents:
diff changeset
  1198
        {
hgs
parents:
diff changeset
  1199
        _LIT( KDescription , "TerminateApp Command For Non-Existent App ID handled successfully");
hgs
parents:
diff changeset
  1200
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1201
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1202
        }
hgs
parents:
diff changeset
  1203
    else
hgs
parents:
diff changeset
  1204
        {
hgs
parents:
diff changeset
  1205
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1206
        _LIT( KDescription , "TerminateApp  Command handling for Non-Existent App Id Failed");
hgs
parents:
diff changeset
  1207
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1208
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1209
        }
hgs
parents:
diff changeset
  1210
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1211
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1212
    delete iTestTimer;
hgs
parents:
diff changeset
  1213
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1214
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1215
    return KErrNone;
hgs
parents:
diff changeset
  1216
    }
hgs
parents:
diff changeset
  1217
hgs
parents:
diff changeset
  1218
TInt CTmServerTest::HandleInvalidAppIdTerminateAppActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  1219
    {
hgs
parents:
diff changeset
  1220
    _LIT( KLogInfo, "Handle Invalid AppId TerminateApp Command" );
hgs
parents:
diff changeset
  1221
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1222
    
hgs
parents:
diff changeset
  1223
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1224
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1225
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1226
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1227
hgs
parents:
diff changeset
  1228
    //Register all the desired applications
hgs
parents:
diff changeset
  1229
    RegisterApplicationsL(*iTmServer);  
hgs
parents:
diff changeset
  1230
    
hgs
parents:
diff changeset
  1231
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1232
    iTmServer->StartL();    
hgs
parents:
diff changeset
  1233
    //Start the control point and search for device
hgs
parents:
diff changeset
  1234
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1235
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1236
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1237
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1238
    
hgs
parents:
diff changeset
  1239
    if ( iDeviceVerified )
hgs
parents:
diff changeset
  1240
        {
hgs
parents:
diff changeset
  1241
         //Terminate the application by specifying invalid appId
hgs
parents:
diff changeset
  1242
         iSearchDevice->TerminateAppActionL(  KInvalidAppIdValue,KProfileIdValue );
hgs
parents:
diff changeset
  1243
        }
hgs
parents:
diff changeset
  1244
    
hgs
parents:
diff changeset
  1245
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1246
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1247
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  1248
    if ( iStopApp)
hgs
parents:
diff changeset
  1249
        {
hgs
parents:
diff changeset
  1250
        _LIT( KDescription , "TerminateApp Command with invalid AppId handled successfully");
hgs
parents:
diff changeset
  1251
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1252
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1253
        }
hgs
parents:
diff changeset
  1254
    else
hgs
parents:
diff changeset
  1255
        {
hgs
parents:
diff changeset
  1256
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1257
        _LIT( KDescription , "TerminateApp Command with invalid AppId handling  Failed");
hgs
parents:
diff changeset
  1258
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1259
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1260
        }
hgs
parents:
diff changeset
  1261
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1262
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1263
    delete iTestTimer;
hgs
parents:
diff changeset
  1264
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1265
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1266
    return KErrNone;
hgs
parents:
diff changeset
  1267
    }
hgs
parents:
diff changeset
  1268
hgs
parents:
diff changeset
  1269
TInt CTmServerTest::HandleInvalidProfileIdTerminateAppActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  1270
    {
hgs
parents:
diff changeset
  1271
    _LIT( KLogInfo, "Handle Invalid ProfileId TerminateApp Command" );
hgs
parents:
diff changeset
  1272
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1273
    
hgs
parents:
diff changeset
  1274
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1275
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1276
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1277
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1278
hgs
parents:
diff changeset
  1279
    //Register all the desired applications
hgs
parents:
diff changeset
  1280
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
  1281
    
hgs
parents:
diff changeset
  1282
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1283
    iTmServer->StartL();    
hgs
parents:
diff changeset
  1284
hgs
parents:
diff changeset
  1285
    //Start the control point and search for device
hgs
parents:
diff changeset
  1286
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1287
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1288
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1289
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1290
    
hgs
parents:
diff changeset
  1291
    if ( iDeviceVerified )
hgs
parents:
diff changeset
  1292
        {
hgs
parents:
diff changeset
  1293
         //Terminate the application by specifying invalid profileId
hgs
parents:
diff changeset
  1294
         iSearchDevice->TerminateAppActionL(  KAppId1Value,KInvalidProfileIdValue );
hgs
parents:
diff changeset
  1295
        }
hgs
parents:
diff changeset
  1296
    
hgs
parents:
diff changeset
  1297
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1298
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1299
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  1300
    if ( iStopApp)
hgs
parents:
diff changeset
  1301
        {
hgs
parents:
diff changeset
  1302
        _LIT( KDescription , "TerminateApp Command with invalid ProfileId handled successfully");
hgs
parents:
diff changeset
  1303
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1304
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1305
        }
hgs
parents:
diff changeset
  1306
    else
hgs
parents:
diff changeset
  1307
        {
hgs
parents:
diff changeset
  1308
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1309
        _LIT( KDescription , "TerminateApp Command with invalid ProfileId handling  Failed");
hgs
parents:
diff changeset
  1310
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1311
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1312
        }
hgs
parents:
diff changeset
  1313
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1314
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1315
    delete iTestTimer;
hgs
parents:
diff changeset
  1316
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1317
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1318
    return KErrNone;
hgs
parents:
diff changeset
  1319
    }
hgs
parents:
diff changeset
  1320
hgs
parents:
diff changeset
  1321
TInt CTmServerTest::HandleUnauthorizedTerminateAppActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  1322
    {
hgs
parents:
diff changeset
  1323
    _LIT( KLogInfo, "Handle TerminateApp Command UnAuthorized AppID" );
hgs
parents:
diff changeset
  1324
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1325
    
hgs
parents:
diff changeset
  1326
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1327
hgs
parents:
diff changeset
  1328
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1329
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1330
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1331
hgs
parents:
diff changeset
  1332
    //Register all the desired applications
hgs
parents:
diff changeset
  1333
    RegisterApplicationsL(*iTmServer);    
hgs
parents:
diff changeset
  1334
    
hgs
parents:
diff changeset
  1335
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1336
    iTmServer->StartL();    
hgs
parents:
diff changeset
  1337
hgs
parents:
diff changeset
  1338
    //Start the control point and search for device
hgs
parents:
diff changeset
  1339
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1340
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1341
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1342
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1343
    
hgs
parents:
diff changeset
  1344
    if ( iDeviceVerified )
hgs
parents:
diff changeset
  1345
        {
hgs
parents:
diff changeset
  1346
         //Terminate the application by specifying unauthorized appId
hgs
parents:
diff changeset
  1347
         iSearchDevice->TerminateAppActionL( KAppId5Value,KProfileIdValue );
hgs
parents:
diff changeset
  1348
        }
hgs
parents:
diff changeset
  1349
    
hgs
parents:
diff changeset
  1350
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1351
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1352
    CActiveScheduler::Start();     
hgs
parents:
diff changeset
  1353
    if ( iStopApp)
hgs
parents:
diff changeset
  1354
        {
hgs
parents:
diff changeset
  1355
        _LIT( KDescription , "TerminateApp Command For Un-Authorized App ID handled successfully");
hgs
parents:
diff changeset
  1356
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1357
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1358
        }
hgs
parents:
diff changeset
  1359
    else
hgs
parents:
diff changeset
  1360
        {
hgs
parents:
diff changeset
  1361
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1362
        _LIT( KDescription , "TerminateApp  Command handling For Un-Authorized App ID Failed");
hgs
parents:
diff changeset
  1363
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1364
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1365
        }
hgs
parents:
diff changeset
  1366
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1367
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1368
    delete iTestTimer;
hgs
parents:
diff changeset
  1369
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1370
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1371
    return KErrNone;
hgs
parents:
diff changeset
  1372
    }
hgs
parents:
diff changeset
  1373
hgs
parents:
diff changeset
  1374
TInt CTmServerTest::HandleDeviceLockedTerminateAppActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  1375
    {
hgs
parents:
diff changeset
  1376
    _LIT( KLogInfo, "Handle Device Locked Condition For TerminateApp Command" );
hgs
parents:
diff changeset
  1377
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1378
    
hgs
parents:
diff changeset
  1379
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1380
    
hgs
parents:
diff changeset
  1381
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1382
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1383
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1384
hgs
parents:
diff changeset
  1385
    //Register all the desired applications
hgs
parents:
diff changeset
  1386
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
  1387
    
hgs
parents:
diff changeset
  1388
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1389
    iTmServer ->StartL();
hgs
parents:
diff changeset
  1390
hgs
parents:
diff changeset
  1391
    //Start the control point and search for device
hgs
parents:
diff changeset
  1392
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1393
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1394
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1395
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1396
hgs
parents:
diff changeset
  1397
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1398
        {
hgs
parents:
diff changeset
  1399
         //Terminate the application
hgs
parents:
diff changeset
  1400
         iSearchDevice->TerminateAppActionL(KAppId4Value,KProfileIdValue);
hgs
parents:
diff changeset
  1401
        }   
hgs
parents:
diff changeset
  1402
    
hgs
parents:
diff changeset
  1403
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1404
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1405
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1406
    if (iStopApp )
hgs
parents:
diff changeset
  1407
        {
hgs
parents:
diff changeset
  1408
       _LIT( KDescription , "TerminateApp Command For Device Locked Condition handled successfully");
hgs
parents:
diff changeset
  1409
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1410
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1411
        }
hgs
parents:
diff changeset
  1412
    else
hgs
parents:
diff changeset
  1413
        {
hgs
parents:
diff changeset
  1414
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1415
        _LIT( KDescription , "TerminateApp Command For Device Locked Condition handling Failed");
hgs
parents:
diff changeset
  1416
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1417
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1418
        }
hgs
parents:
diff changeset
  1419
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1420
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1421
    delete iTestTimer;
hgs
parents:
diff changeset
  1422
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1423
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1424
    return KErrNone;
hgs
parents:
diff changeset
  1425
    }
hgs
parents:
diff changeset
  1426
hgs
parents:
diff changeset
  1427
TInt CTmServerTest::HandleGetAppStatusActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  1428
    {
hgs
parents:
diff changeset
  1429
    _LIT( KLogInfo, "Handle GetAppStatus Command" );
hgs
parents:
diff changeset
  1430
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1431
    
hgs
parents:
diff changeset
  1432
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1433
hgs
parents:
diff changeset
  1434
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1435
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1436
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1437
hgs
parents:
diff changeset
  1438
    //Register all the desired applications
hgs
parents:
diff changeset
  1439
    RegisterApplicationsL(*iTmServer);     
hgs
parents:
diff changeset
  1440
hgs
parents:
diff changeset
  1441
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1442
    iTmServer->StartL();   
hgs
parents:
diff changeset
  1443
    
hgs
parents:
diff changeset
  1444
    //Start the control point and search for device
hgs
parents:
diff changeset
  1445
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1446
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1447
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1448
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1449
hgs
parents:
diff changeset
  1450
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1451
        {
hgs
parents:
diff changeset
  1452
         //Retrieve the status of application
hgs
parents:
diff changeset
  1453
         iSearchDevice->GetAppStatusActionL( KAppId1Value );
hgs
parents:
diff changeset
  1454
        }
hgs
parents:
diff changeset
  1455
    
hgs
parents:
diff changeset
  1456
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1457
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1458
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1459
hgs
parents:
diff changeset
  1460
    if (iGetAppStatus)
hgs
parents:
diff changeset
  1461
        {
hgs
parents:
diff changeset
  1462
        _LIT( KDescription , "GetAppStatus Command  handled successfully");
hgs
parents:
diff changeset
  1463
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1464
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1465
        }
hgs
parents:
diff changeset
  1466
    else
hgs
parents:
diff changeset
  1467
        {
hgs
parents:
diff changeset
  1468
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1469
        _LIT( KDescription , "GetAppStatus Command handling Failed");
hgs
parents:
diff changeset
  1470
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1471
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1472
        }
hgs
parents:
diff changeset
  1473
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1474
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1475
    delete iTestTimer;
hgs
parents:
diff changeset
  1476
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1477
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1478
    return KErrNone;
hgs
parents:
diff changeset
  1479
    }
hgs
parents:
diff changeset
  1480
hgs
parents:
diff changeset
  1481
TInt CTmServerTest::HandleWildcardGetAppStatusActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  1482
    {
hgs
parents:
diff changeset
  1483
    _LIT( KLogInfo, "Handle GetAppStatus Command For All the Applications" );
hgs
parents:
diff changeset
  1484
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1485
    
hgs
parents:
diff changeset
  1486
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1487
hgs
parents:
diff changeset
  1488
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1489
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1490
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1491
    
hgs
parents:
diff changeset
  1492
    //Register all the desired applications
hgs
parents:
diff changeset
  1493
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
  1494
    
hgs
parents:
diff changeset
  1495
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1496
    iTmServer->StartL();   
hgs
parents:
diff changeset
  1497
hgs
parents:
diff changeset
  1498
    //Start the control point and search for device
hgs
parents:
diff changeset
  1499
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1500
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1501
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1502
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1503
hgs
parents:
diff changeset
  1504
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1505
        {
hgs
parents:
diff changeset
  1506
         //Retrieve the status of all the application
hgs
parents:
diff changeset
  1507
         iSearchDevice->GetAppStatusActionL( KAppId5Value );
hgs
parents:
diff changeset
  1508
        }
hgs
parents:
diff changeset
  1509
    
hgs
parents:
diff changeset
  1510
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1511
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1512
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1513
hgs
parents:
diff changeset
  1514
    if (iGetAppStatus)
hgs
parents:
diff changeset
  1515
        {
hgs
parents:
diff changeset
  1516
        _LIT( KDescription , "GetAppStatus Command  handled successfully");
hgs
parents:
diff changeset
  1517
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1518
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1519
        }
hgs
parents:
diff changeset
  1520
    else
hgs
parents:
diff changeset
  1521
        {
hgs
parents:
diff changeset
  1522
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1523
        _LIT( KDescription , "GetAppStatus Command handling Failed");
hgs
parents:
diff changeset
  1524
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1525
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1526
        }
hgs
parents:
diff changeset
  1527
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1528
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1529
    delete iTestTimer;
hgs
parents:
diff changeset
  1530
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1531
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1532
    return KErrNone;
hgs
parents:
diff changeset
  1533
    }
hgs
parents:
diff changeset
  1534
hgs
parents:
diff changeset
  1535
hgs
parents:
diff changeset
  1536
TInt CTmServerTest::HandleInvalidAppIdGetAppStatusActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  1537
    {
hgs
parents:
diff changeset
  1538
    _LIT( KLogInfo, "Handle GetAppStatus Command For Invalid AppId" );
hgs
parents:
diff changeset
  1539
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1540
    
hgs
parents:
diff changeset
  1541
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1542
hgs
parents:
diff changeset
  1543
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1544
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1545
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1546
    
hgs
parents:
diff changeset
  1547
    //Register all the desired applications
hgs
parents:
diff changeset
  1548
    RegisterApplicationsL(*iTmServer);    
hgs
parents:
diff changeset
  1549
    
hgs
parents:
diff changeset
  1550
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1551
    iTmServer->StartL();
hgs
parents:
diff changeset
  1552
    
hgs
parents:
diff changeset
  1553
    //Start the control point and search for device
hgs
parents:
diff changeset
  1554
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1555
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1556
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1557
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1558
hgs
parents:
diff changeset
  1559
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1560
        { 
hgs
parents:
diff changeset
  1561
         //Retrieve the status of the application by specifying invalid appId
hgs
parents:
diff changeset
  1562
         iSearchDevice->GetAppStatusActionL( KInvalidAppIdValue );
hgs
parents:
diff changeset
  1563
        }
hgs
parents:
diff changeset
  1564
    
hgs
parents:
diff changeset
  1565
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1566
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1567
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1568
hgs
parents:
diff changeset
  1569
    if (iGetAppStatus)
hgs
parents:
diff changeset
  1570
        {
hgs
parents:
diff changeset
  1571
        _LIT( KDescription , "GetAppStatus Command with invalid AppId  handled successfully");
hgs
parents:
diff changeset
  1572
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1573
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1574
        }
hgs
parents:
diff changeset
  1575
    else
hgs
parents:
diff changeset
  1576
        {
hgs
parents:
diff changeset
  1577
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1578
        _LIT( KDescription , "GetAppStatus Command with invalid AppId handling  Failed");
hgs
parents:
diff changeset
  1579
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1580
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1581
        }
hgs
parents:
diff changeset
  1582
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1583
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1584
    delete iTestTimer;
hgs
parents:
diff changeset
  1585
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1586
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1587
    return KErrNone;
hgs
parents:
diff changeset
  1588
    }
hgs
parents:
diff changeset
  1589
hgs
parents:
diff changeset
  1590
TInt CTmServerTest::HandleNonExistentGetAppStatusActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  1591
    {
hgs
parents:
diff changeset
  1592
    _LIT( KLogInfo, "Handle GetAppStatus Command For Non-Existent AppID" );
hgs
parents:
diff changeset
  1593
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1594
    
hgs
parents:
diff changeset
  1595
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1596
hgs
parents:
diff changeset
  1597
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1598
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1599
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1600
    
hgs
parents:
diff changeset
  1601
    //Register all the desired applications
hgs
parents:
diff changeset
  1602
    RegisterApplicationsL(*iTmServer);  
hgs
parents:
diff changeset
  1603
    
hgs
parents:
diff changeset
  1604
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1605
    iTmServer->StartL();  
hgs
parents:
diff changeset
  1606
    
hgs
parents:
diff changeset
  1607
    //Start the control point and search for device
hgs
parents:
diff changeset
  1608
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1609
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1610
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1611
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1612
hgs
parents:
diff changeset
  1613
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1614
        {
hgs
parents:
diff changeset
  1615
         //Retrieve the status of the application by specifying non existent appId
hgs
parents:
diff changeset
  1616
         iSearchDevice->GetAppStatusActionL( KNonExistentAppIdValue );
hgs
parents:
diff changeset
  1617
        }
hgs
parents:
diff changeset
  1618
    
hgs
parents:
diff changeset
  1619
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1620
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1621
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1622
hgs
parents:
diff changeset
  1623
    if (iGetAppStatus)
hgs
parents:
diff changeset
  1624
        {
hgs
parents:
diff changeset
  1625
        _LIT( KDescription , "GetAppStatus Command for Non-Existent App ID handled successfully");
hgs
parents:
diff changeset
  1626
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1627
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1628
        }
hgs
parents:
diff changeset
  1629
    else
hgs
parents:
diff changeset
  1630
        {
hgs
parents:
diff changeset
  1631
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1632
        _LIT( KDescription , "GetAppStatus Command handling for Non-Existent App ID Failed");
hgs
parents:
diff changeset
  1633
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1634
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1635
        }
hgs
parents:
diff changeset
  1636
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1637
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1638
    delete iTestTimer;
hgs
parents:
diff changeset
  1639
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1640
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1641
    return KErrNone;
hgs
parents:
diff changeset
  1642
    }
hgs
parents:
diff changeset
  1643
hgs
parents:
diff changeset
  1644
TInt CTmServerTest::HandleEventAppStatusUpdateL( TTestResult& aResult )
hgs
parents:
diff changeset
  1645
 {
hgs
parents:
diff changeset
  1646
    _LIT( KLogInfo, "Handle Event For AppStatus Update" );
hgs
parents:
diff changeset
  1647
    iLog->Log( KLogInfo ); 
hgs
parents:
diff changeset
  1648
       
hgs
parents:
diff changeset
  1649
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1650
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1651
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1652
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1653
hgs
parents:
diff changeset
  1654
    //Register all the desired applications 
hgs
parents:
diff changeset
  1655
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
  1656
    
hgs
parents:
diff changeset
  1657
    //Start the tmserver device and its services              
hgs
parents:
diff changeset
  1658
    iTmServer ->StartL();
hgs
parents:
diff changeset
  1659
hgs
parents:
diff changeset
  1660
    //Start the control point and search for device
hgs
parents:
diff changeset
  1661
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1662
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1663
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1664
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1665
       
hgs
parents:
diff changeset
  1666
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1667
         {
hgs
parents:
diff changeset
  1668
          //Subscribes to a service 
hgs
parents:
diff changeset
  1669
          iSearchDevice->SubscribeToServiceL();
hgs
parents:
diff changeset
  1670
         }
hgs
parents:
diff changeset
  1671
    RArray<TUint> updatedAppIdList;
hgs
parents:
diff changeset
  1672
    updatedAppIdList.Append(KAppId1Value);
hgs
parents:
diff changeset
  1673
    updatedAppIdList.Append(KAppId2Value);
hgs
parents:
diff changeset
  1674
    
hgs
parents:
diff changeset
  1675
    //Update the status of applications which have undergone some change
hgs
parents:
diff changeset
  1676
    iTmServer->UpdateAppStatusL(updatedAppIdList); 
hgs
parents:
diff changeset
  1677
    
hgs
parents:
diff changeset
  1678
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1679
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1680
    CActiveScheduler::Start();
hgs
parents:
diff changeset
  1681
    
hgs
parents:
diff changeset
  1682
    if ( iStatusNotified )
hgs
parents:
diff changeset
  1683
         {
hgs
parents:
diff changeset
  1684
          _LIT( KDescription , "Handle Event For AppStatus Update handled successfully");
hgs
parents:
diff changeset
  1685
          aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1686
          iLog->Log( KDescription );
hgs
parents:
diff changeset
  1687
         }
hgs
parents:
diff changeset
  1688
    else
hgs
parents:
diff changeset
  1689
         {
hgs
parents:
diff changeset
  1690
          aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1691
          _LIT( KDescription , "Handle Event For AppStatus Update handling Failed");
hgs
parents:
diff changeset
  1692
          aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1693
          iLog->Log( KDescription );
hgs
parents:
diff changeset
  1694
         }
hgs
parents:
diff changeset
  1695
    updatedAppIdList.Close();
hgs
parents:
diff changeset
  1696
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1697
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1698
    delete iTestTimer;
hgs
parents:
diff changeset
  1699
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1700
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1701
    return KErrNone;
hgs
parents:
diff changeset
  1702
  }
hgs
parents:
diff changeset
  1703
hgs
parents:
diff changeset
  1704
TInt CTmServerTest::HandleEventAppListUpdateL( TTestResult& aResult )
hgs
parents:
diff changeset
  1705
 {
hgs
parents:
diff changeset
  1706
    _LIT( KLogInfo, "Handle Event For AppList Update" );
hgs
parents:
diff changeset
  1707
    iLog->Log( KLogInfo ); 
hgs
parents:
diff changeset
  1708
       
hgs
parents:
diff changeset
  1709
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1710
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1711
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1712
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1713
hgs
parents:
diff changeset
  1714
    //Register all the desired applications 
hgs
parents:
diff changeset
  1715
    RegisterApplicationsL(*iTmServer);
hgs
parents:
diff changeset
  1716
    
hgs
parents:
diff changeset
  1717
    //Start the tmserver device and its services              
hgs
parents:
diff changeset
  1718
    iTmServer ->StartL();
hgs
parents:
diff changeset
  1719
hgs
parents:
diff changeset
  1720
    //Start the control point and search for device
hgs
parents:
diff changeset
  1721
    iSearchDevice = CDiscoverDevice::NewL(*this);          
hgs
parents:
diff changeset
  1722
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1723
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1724
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  1725
          
hgs
parents:
diff changeset
  1726
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1727
         {
hgs
parents:
diff changeset
  1728
          //Subscribes to a service 
hgs
parents:
diff changeset
  1729
          iSearchDevice->SubscribeToServiceL();        
hgs
parents:
diff changeset
  1730
         }  
hgs
parents:
diff changeset
  1731
      
hgs
parents:
diff changeset
  1732
    TInt errorCode;
hgs
parents:
diff changeset
  1733
    CUpnpRemotableApp& aRemotableApp = iTmServer->GetRemotableApp(KAppIdValue ,errorCode );
hgs
parents:
diff changeset
  1734
    if (errorCode == KErrNone)
hgs
parents:
diff changeset
  1735
        { 
hgs
parents:
diff changeset
  1736
         _LIT8(KAppDesc, "Mobile Device Display");
hgs
parents:
diff changeset
  1737
         aRemotableApp.SetAppDescriptionL(KAppDesc());
hgs
parents:
diff changeset
  1738
        }
hgs
parents:
diff changeset
  1739
    RArray<TUint> updatedAppIdList;
hgs
parents:
diff changeset
  1740
    updatedAppIdList.Append(KAppIdValue);
hgs
parents:
diff changeset
  1741
    updatedAppIdList.Append(KAppId2Value);
hgs
parents:
diff changeset
  1742
   
hgs
parents:
diff changeset
  1743
    //Update the list of applications which have been modified to/from the list
hgs
parents:
diff changeset
  1744
    iTmServer->UpdateAppListL(updatedAppIdList);      
hgs
parents:
diff changeset
  1745
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1746
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1747
    CActiveScheduler::Start();
hgs
parents:
diff changeset
  1748
    
hgs
parents:
diff changeset
  1749
    if ( iStatusNotified )
hgs
parents:
diff changeset
  1750
         {
hgs
parents:
diff changeset
  1751
          _LIT( KDescription , "Handle Event For AppList Update handled successfully");
hgs
parents:
diff changeset
  1752
          aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1753
          iLog->Log( KDescription );
hgs
parents:
diff changeset
  1754
         }
hgs
parents:
diff changeset
  1755
    else
hgs
parents:
diff changeset
  1756
         {
hgs
parents:
diff changeset
  1757
          aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1758
          _LIT( KDescription , "Handle Event For AppList Update handling Failed");
hgs
parents:
diff changeset
  1759
          aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1760
          iLog->Log( KDescription );
hgs
parents:
diff changeset
  1761
         }
hgs
parents:
diff changeset
  1762
    updatedAppIdList.Close();
hgs
parents:
diff changeset
  1763
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1764
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1765
    delete iTestTimer;
hgs
parents:
diff changeset
  1766
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1767
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1768
    return KErrNone;
hgs
parents:
diff changeset
  1769
  }
hgs
parents:
diff changeset
  1770
hgs
parents:
diff changeset
  1771
TInt CTmServerTest::HandleGetAppListActionFilter1L ( TTestResult& aResult )
hgs
parents:
diff changeset
  1772
    {
hgs
parents:
diff changeset
  1773
    _LIT( KLogInfo, "Handle GetAppList Command with Filter1" );
hgs
parents:
diff changeset
  1774
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1775
    
hgs
parents:
diff changeset
  1776
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1777
hgs
parents:
diff changeset
  1778
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1779
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1780
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1781
    
hgs
parents:
diff changeset
  1782
    //Register all the desired applications
hgs
parents:
diff changeset
  1783
    RegisterApplicationsL(*iTmServer);  
hgs
parents:
diff changeset
  1784
    
hgs
parents:
diff changeset
  1785
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1786
    iTmServer->StartL();   
hgs
parents:
diff changeset
  1787
    
hgs
parents:
diff changeset
  1788
    //Start the control point and search for device
hgs
parents:
diff changeset
  1789
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1790
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1791
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1792
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1793
hgs
parents:
diff changeset
  1794
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1795
        {
hgs
parents:
diff changeset
  1796
          //Retrieve the list of applications by specifying filter value
hgs
parents:
diff changeset
  1797
          iSearchDevice->GetAppListActionL(KAppListFilterValue1(),KProfileIdValue);
hgs
parents:
diff changeset
  1798
        }
hgs
parents:
diff changeset
  1799
    
hgs
parents:
diff changeset
  1800
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1801
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1802
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  1803
    if (iGetAppList)
hgs
parents:
diff changeset
  1804
        {
hgs
parents:
diff changeset
  1805
        _LIT( KDescription , "GetAppList Command with Filter1 handled successfully");
hgs
parents:
diff changeset
  1806
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1807
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1808
        }
hgs
parents:
diff changeset
  1809
    else
hgs
parents:
diff changeset
  1810
        {
hgs
parents:
diff changeset
  1811
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1812
        _LIT( KDescription , "GetAppList Command with Filter1 handling Failed");
hgs
parents:
diff changeset
  1813
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1814
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1815
        }
hgs
parents:
diff changeset
  1816
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1817
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1818
    delete iTestTimer;
hgs
parents:
diff changeset
  1819
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1820
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1821
    return KErrNone;
hgs
parents:
diff changeset
  1822
    }
hgs
parents:
diff changeset
  1823
hgs
parents:
diff changeset
  1824
TInt CTmServerTest::HandleGetAppListActionFilter2L ( TTestResult& aResult )
hgs
parents:
diff changeset
  1825
    {
hgs
parents:
diff changeset
  1826
    _LIT( KLogInfo, "Handle GetAppList with Filter2 Command" );
hgs
parents:
diff changeset
  1827
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1828
    
hgs
parents:
diff changeset
  1829
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1830
hgs
parents:
diff changeset
  1831
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1832
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1833
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1834
hgs
parents:
diff changeset
  1835
    //Register all the desired applications
hgs
parents:
diff changeset
  1836
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
  1837
    
hgs
parents:
diff changeset
  1838
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1839
    iTmServer->StartL();   
hgs
parents:
diff changeset
  1840
    
hgs
parents:
diff changeset
  1841
    //Start the control point and search for device
hgs
parents:
diff changeset
  1842
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1843
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1844
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1845
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1846
hgs
parents:
diff changeset
  1847
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1848
        {
hgs
parents:
diff changeset
  1849
         //Retrieve the list of applications by specifying filter value
hgs
parents:
diff changeset
  1850
         iSearchDevice->GetAppListActionL(KAppListFilterValue2(),KProfileIdValue);
hgs
parents:
diff changeset
  1851
        }
hgs
parents:
diff changeset
  1852
    
hgs
parents:
diff changeset
  1853
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1854
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1855
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  1856
    if (iGetAppList)
hgs
parents:
diff changeset
  1857
        {
hgs
parents:
diff changeset
  1858
        _LIT( KDescription , "GetAppList Command with Filter2 handled successfully");
hgs
parents:
diff changeset
  1859
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1860
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1861
        }
hgs
parents:
diff changeset
  1862
    else
hgs
parents:
diff changeset
  1863
        {
hgs
parents:
diff changeset
  1864
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1865
        _LIT( KDescription , "GetAppList Command with Filter2 handling Failed");
hgs
parents:
diff changeset
  1866
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1867
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1868
        }
hgs
parents:
diff changeset
  1869
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1870
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1871
    delete iTestTimer;
hgs
parents:
diff changeset
  1872
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1873
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1874
    return KErrNone;
hgs
parents:
diff changeset
  1875
    }
hgs
parents:
diff changeset
  1876
hgs
parents:
diff changeset
  1877
TInt CTmServerTest::HandleGetAppListActionFilter3L ( TTestResult& aResult )
hgs
parents:
diff changeset
  1878
    {
hgs
parents:
diff changeset
  1879
    _LIT( KLogInfo, "Handle GetAppList with Filter3 Command" );
hgs
parents:
diff changeset
  1880
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1881
    
hgs
parents:
diff changeset
  1882
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1883
hgs
parents:
diff changeset
  1884
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1885
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1886
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1887
hgs
parents:
diff changeset
  1888
    //Register all the desired applications
hgs
parents:
diff changeset
  1889
    RegisterApplicationsL(*iTmServer);  
hgs
parents:
diff changeset
  1890
    
hgs
parents:
diff changeset
  1891
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1892
    iTmServer->StartL();   
hgs
parents:
diff changeset
  1893
    
hgs
parents:
diff changeset
  1894
    //Start the control point and search for device
hgs
parents:
diff changeset
  1895
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1896
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1897
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1898
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1899
hgs
parents:
diff changeset
  1900
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1901
        {
hgs
parents:
diff changeset
  1902
         //Retrieve the list of applications by specifying filter value 
hgs
parents:
diff changeset
  1903
         iSearchDevice->GetAppListActionL(KAppListFilterValue3(),KProfileIdValue);
hgs
parents:
diff changeset
  1904
        }
hgs
parents:
diff changeset
  1905
    
hgs
parents:
diff changeset
  1906
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1907
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1908
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  1909
    if (iGetAppList)
hgs
parents:
diff changeset
  1910
        {
hgs
parents:
diff changeset
  1911
        _LIT( KDescription , "GetAppList Command with Filter3 handled successfully");
hgs
parents:
diff changeset
  1912
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1913
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1914
        }
hgs
parents:
diff changeset
  1915
    else
hgs
parents:
diff changeset
  1916
        {
hgs
parents:
diff changeset
  1917
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1918
        _LIT( KDescription , "GetAppList Command with Filter3 handling Failed");
hgs
parents:
diff changeset
  1919
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1920
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1921
        }
hgs
parents:
diff changeset
  1922
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1923
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1924
    delete iTestTimer;
hgs
parents:
diff changeset
  1925
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1926
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1927
    return KErrNone;
hgs
parents:
diff changeset
  1928
    }
hgs
parents:
diff changeset
  1929
hgs
parents:
diff changeset
  1930
TInt CTmServerTest::HandleGetAppListActionFilter4L ( TTestResult& aResult )
hgs
parents:
diff changeset
  1931
    {
hgs
parents:
diff changeset
  1932
    _LIT( KLogInfo, "Handle GetAppList with Filter4 Command" );
hgs
parents:
diff changeset
  1933
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1934
    
hgs
parents:
diff changeset
  1935
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1936
hgs
parents:
diff changeset
  1937
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1938
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1939
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1940
hgs
parents:
diff changeset
  1941
    //Register all the desired applications
hgs
parents:
diff changeset
  1942
    RegisterApplicationsL(*iTmServer);  
hgs
parents:
diff changeset
  1943
    
hgs
parents:
diff changeset
  1944
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1945
    iTmServer->StartL();   
hgs
parents:
diff changeset
  1946
    
hgs
parents:
diff changeset
  1947
    //Start the control point and search for device
hgs
parents:
diff changeset
  1948
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  1949
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1950
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  1951
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  1952
hgs
parents:
diff changeset
  1953
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  1954
        {
hgs
parents:
diff changeset
  1955
         //Retrieve the list of applications by specifying filter value 
hgs
parents:
diff changeset
  1956
         iSearchDevice->GetAppListActionL(KAppListFilterValue4(),KProfileIdValue);
hgs
parents:
diff changeset
  1957
        }
hgs
parents:
diff changeset
  1958
    
hgs
parents:
diff changeset
  1959
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  1960
    iTestTimer->After(15);
hgs
parents:
diff changeset
  1961
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  1962
    if (iGetAppList)
hgs
parents:
diff changeset
  1963
        {
hgs
parents:
diff changeset
  1964
        _LIT( KDescription , "GetAppList Command with Filter4 handled successfully");
hgs
parents:
diff changeset
  1965
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1966
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1967
        }
hgs
parents:
diff changeset
  1968
    else
hgs
parents:
diff changeset
  1969
        {
hgs
parents:
diff changeset
  1970
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  1971
        _LIT( KDescription , "GetAppList Command with Filter4 handling Failed");
hgs
parents:
diff changeset
  1972
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  1973
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  1974
        }
hgs
parents:
diff changeset
  1975
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  1976
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  1977
    delete iTestTimer;
hgs
parents:
diff changeset
  1978
    iTestTimer = NULL;
hgs
parents:
diff changeset
  1979
    REComSession::FinalClose();
hgs
parents:
diff changeset
  1980
    return KErrNone;
hgs
parents:
diff changeset
  1981
    }
hgs
parents:
diff changeset
  1982
hgs
parents:
diff changeset
  1983
TInt CTmServerTest::HandleGetAppListActionInvalidArg1L ( TTestResult& aResult )
hgs
parents:
diff changeset
  1984
    {
hgs
parents:
diff changeset
  1985
    _LIT( KLogInfo, "Handle GetAppList Command with Invalid Arg1" );
hgs
parents:
diff changeset
  1986
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  1987
    
hgs
parents:
diff changeset
  1988
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  1989
hgs
parents:
diff changeset
  1990
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  1991
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  1992
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  1993
hgs
parents:
diff changeset
  1994
    //Register all the desired applications
hgs
parents:
diff changeset
  1995
    RegisterApplicationsL(*iTmServer);    
hgs
parents:
diff changeset
  1996
    
hgs
parents:
diff changeset
  1997
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  1998
    iTmServer->StartL();   
hgs
parents:
diff changeset
  1999
    
hgs
parents:
diff changeset
  2000
    //Start the control point and search for device
hgs
parents:
diff changeset
  2001
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2002
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2003
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2004
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2005
hgs
parents:
diff changeset
  2006
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2007
        {
hgs
parents:
diff changeset
  2008
          _LIT8(KInvalidFilter1,"\"name=\"*Audio*\"" );
hgs
parents:
diff changeset
  2009
         //Retrieve the list of applications by specifying invalid filter value
hgs
parents:
diff changeset
  2010
         iSearchDevice->GetAppListActionL(KInvalidFilter1(),KProfileIdValue);  
hgs
parents:
diff changeset
  2011
        }
hgs
parents:
diff changeset
  2012
    
hgs
parents:
diff changeset
  2013
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2014
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2015
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  2016
    if (iGetAppList)
hgs
parents:
diff changeset
  2017
        {
hgs
parents:
diff changeset
  2018
        _LIT( KDescription , "GetAppList Command with Invalid Arg1 handled successfully");
hgs
parents:
diff changeset
  2019
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2020
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2021
        }
hgs
parents:
diff changeset
  2022
    else
hgs
parents:
diff changeset
  2023
        {
hgs
parents:
diff changeset
  2024
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2025
        _LIT( KDescription , "GetAppList Command with Invalid Arg1 handling Failed");
hgs
parents:
diff changeset
  2026
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2027
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2028
        }
hgs
parents:
diff changeset
  2029
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2030
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2031
    delete iTestTimer;
hgs
parents:
diff changeset
  2032
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2033
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2034
    return KErrNone;
hgs
parents:
diff changeset
  2035
    }
hgs
parents:
diff changeset
  2036
hgs
parents:
diff changeset
  2037
hgs
parents:
diff changeset
  2038
TInt CTmServerTest::HandleGetAppListActionInvalidArg2L ( TTestResult& aResult )
hgs
parents:
diff changeset
  2039
    {
hgs
parents:
diff changeset
  2040
    _LIT( KLogInfo, "Handle GetAppList Command with Invalid Arg2" );
hgs
parents:
diff changeset
  2041
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2042
    
hgs
parents:
diff changeset
  2043
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2044
hgs
parents:
diff changeset
  2045
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2046
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2047
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2048
hgs
parents:
diff changeset
  2049
    //Register all the desired applications
hgs
parents:
diff changeset
  2050
    RegisterApplicationsL(*iTmServer);  
hgs
parents:
diff changeset
  2051
    
hgs
parents:
diff changeset
  2052
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2053
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2054
    
hgs
parents:
diff changeset
  2055
    //Start the control point and search for device
hgs
parents:
diff changeset
  2056
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2057
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2058
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2059
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2060
hgs
parents:
diff changeset
  2061
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2062
        {
hgs
parents:
diff changeset
  2063
         _LIT8(KInvalidFilter2, "\"name=\"*nav*\",appInfo=\"*\"\""); 
hgs
parents:
diff changeset
  2064
         //Retrieve the list of applications by specifying invalid filter value
hgs
parents:
diff changeset
  2065
         iSearchDevice->GetAppListActionL(KInvalidFilter2(),KProfileIdValue);
hgs
parents:
diff changeset
  2066
        }
hgs
parents:
diff changeset
  2067
    
hgs
parents:
diff changeset
  2068
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2069
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2070
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  2071
    if (iGetAppList)
hgs
parents:
diff changeset
  2072
        {
hgs
parents:
diff changeset
  2073
        _LIT( KDescription , "GetAppList Command with Invalid Arg2 handled successfully");
hgs
parents:
diff changeset
  2074
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2075
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2076
        }
hgs
parents:
diff changeset
  2077
    else
hgs
parents:
diff changeset
  2078
        {
hgs
parents:
diff changeset
  2079
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2080
        _LIT( KDescription , "GetAppList Command with Invalid Arg2 handling Failed");
hgs
parents:
diff changeset
  2081
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2082
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2083
        }
hgs
parents:
diff changeset
  2084
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2085
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2086
    delete iTestTimer;
hgs
parents:
diff changeset
  2087
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2088
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2089
    return KErrNone;
hgs
parents:
diff changeset
  2090
    }
hgs
parents:
diff changeset
  2091
hgs
parents:
diff changeset
  2092
TInt CTmServerTest::HandleGetAppListActionInvalidArg3L ( TTestResult& aResult )
hgs
parents:
diff changeset
  2093
    {
hgs
parents:
diff changeset
  2094
    _LIT( KLogInfo, "Handle GetAppList Command with Invalid Arg3" );
hgs
parents:
diff changeset
  2095
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2096
    
hgs
parents:
diff changeset
  2097
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2098
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2099
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2100
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2101
hgs
parents:
diff changeset
  2102
    //Register all the desired applications
hgs
parents:
diff changeset
  2103
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
  2104
    
hgs
parents:
diff changeset
  2105
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2106
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2107
    
hgs
parents:
diff changeset
  2108
    //Start the control point and search for device
hgs
parents:
diff changeset
  2109
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2110
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2111
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2112
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2113
hgs
parents:
diff changeset
  2114
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2115
        {
hgs
parents:
diff changeset
  2116
         _LIT8(KInvalidFilter3, "\"name=\"*Audio*\",@audioType=\"*\"\"");
hgs
parents:
diff changeset
  2117
         //Retrieve the list of applications by specifying invalid filter value
hgs
parents:
diff changeset
  2118
         iSearchDevice->GetAppListActionL(KInvalidFilter3(),KProfileIdValue);
hgs
parents:
diff changeset
  2119
        }
hgs
parents:
diff changeset
  2120
    
hgs
parents:
diff changeset
  2121
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2122
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2123
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  2124
    if (iGetAppList)
hgs
parents:
diff changeset
  2125
        {
hgs
parents:
diff changeset
  2126
        _LIT( KDescription , "GetAppList Command with Invalid Arg3 handled successfully");
hgs
parents:
diff changeset
  2127
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2128
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2129
        }
hgs
parents:
diff changeset
  2130
    else
hgs
parents:
diff changeset
  2131
        {
hgs
parents:
diff changeset
  2132
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2133
        _LIT( KDescription , "GetAppList Command with Invalid Arg3 handling Failed");
hgs
parents:
diff changeset
  2134
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2135
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2136
        }
hgs
parents:
diff changeset
  2137
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2138
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2139
    delete iTestTimer;
hgs
parents:
diff changeset
  2140
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2141
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2142
    return KErrNone;
hgs
parents:
diff changeset
  2143
    }
hgs
parents:
diff changeset
  2144
hgs
parents:
diff changeset
  2145
TInt CTmServerTest::HandleGetAppListActionInvalidArg4L ( TTestResult& aResult )
hgs
parents:
diff changeset
  2146
    {
hgs
parents:
diff changeset
  2147
    _LIT( KLogInfo, "Handle GetAppList Command with Invalid Arg4" );
hgs
parents:
diff changeset
  2148
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2149
    
hgs
parents:
diff changeset
  2150
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2151
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2152
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2153
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2154
hgs
parents:
diff changeset
  2155
    //Register all the desired applications
hgs
parents:
diff changeset
  2156
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
  2157
    
hgs
parents:
diff changeset
  2158
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2159
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2160
    
hgs
parents:
diff changeset
  2161
    //Start the control point and search for device
hgs
parents:
diff changeset
  2162
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2163
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2164
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2165
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2166
hgs
parents:
diff changeset
  2167
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2168
        {
hgs
parents:
diff changeset
  2169
         _LIT8(KInvalidFilter4, "\"icon@mimetype\"*svg+xml*\"\"");
hgs
parents:
diff changeset
  2170
         //Retrieve the list of applications by specifying invalid filter value
hgs
parents:
diff changeset
  2171
         iSearchDevice->GetAppListActionL(KInvalidFilter4(),KProfileIdValue);
hgs
parents:
diff changeset
  2172
        }
hgs
parents:
diff changeset
  2173
    
hgs
parents:
diff changeset
  2174
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2175
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2176
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  2177
    if (iGetAppList)
hgs
parents:
diff changeset
  2178
        {
hgs
parents:
diff changeset
  2179
        _LIT( KDescription , "GetAppList Command with Invalid Arg4 handled successfully");
hgs
parents:
diff changeset
  2180
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2181
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2182
        }
hgs
parents:
diff changeset
  2183
    else
hgs
parents:
diff changeset
  2184
        {
hgs
parents:
diff changeset
  2185
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2186
        _LIT( KDescription , "GetAppList Command with Invalid Arg4 handling Failed");
hgs
parents:
diff changeset
  2187
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2188
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2189
        }
hgs
parents:
diff changeset
  2190
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2191
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2192
    delete iTestTimer;
hgs
parents:
diff changeset
  2193
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2194
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2195
    return KErrNone;
hgs
parents:
diff changeset
  2196
    }
hgs
parents:
diff changeset
  2197
hgs
parents:
diff changeset
  2198
TInt CTmServerTest::HandleGetAppListActionInvalidArg5L ( TTestResult& aResult )
hgs
parents:
diff changeset
  2199
    {
hgs
parents:
diff changeset
  2200
    _LIT( KLogInfo, "Handle GetAppList Command with Invalid Arg5" );
hgs
parents:
diff changeset
  2201
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2202
    
hgs
parents:
diff changeset
  2203
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2204
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2205
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2206
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2207
hgs
parents:
diff changeset
  2208
    //Register all the desired applications
hgs
parents:
diff changeset
  2209
    RegisterApplicationsL(*iTmServer);   
hgs
parents:
diff changeset
  2210
    
hgs
parents:
diff changeset
  2211
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2212
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2213
    
hgs
parents:
diff changeset
  2214
    //Start the control point and search for device
hgs
parents:
diff changeset
  2215
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2216
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2217
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2218
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2219
hgs
parents:
diff changeset
  2220
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2221
        {
hgs
parents:
diff changeset
  2222
         _LIT8(KInvalidFilter5, "\"name=\"*nav*\"appInfo@appCategory=\"*\"\"");
hgs
parents:
diff changeset
  2223
         //Retrieve the list of applications by specifying invalid filter value
hgs
parents:
diff changeset
  2224
         iSearchDevice->GetAppListActionL(KInvalidFilter5(),KProfileIdValue);
hgs
parents:
diff changeset
  2225
        }
hgs
parents:
diff changeset
  2226
    
hgs
parents:
diff changeset
  2227
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2228
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2229
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  2230
    if (iGetAppList)
hgs
parents:
diff changeset
  2231
        {
hgs
parents:
diff changeset
  2232
        _LIT( KDescription , "GetAppList Command with Invalid Arg5 handled successfully");
hgs
parents:
diff changeset
  2233
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2234
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2235
        }
hgs
parents:
diff changeset
  2236
    else
hgs
parents:
diff changeset
  2237
        {
hgs
parents:
diff changeset
  2238
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2239
        _LIT( KDescription , "GetAppList Command with Invalid Arg5 handling Failed");
hgs
parents:
diff changeset
  2240
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2241
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2242
        }
hgs
parents:
diff changeset
  2243
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2244
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2245
    delete iTestTimer;
hgs
parents:
diff changeset
  2246
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2247
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2248
    return KErrNone;
hgs
parents:
diff changeset
  2249
    }
hgs
parents:
diff changeset
  2250
hgs
parents:
diff changeset
  2251
TInt CTmServerTest::HandleGetAppListActionNoFilterL ( TTestResult& aResult )
hgs
parents:
diff changeset
  2252
    {
hgs
parents:
diff changeset
  2253
    _LIT( KLogInfo, "Handle GetAppList Command With No Filter" );
hgs
parents:
diff changeset
  2254
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2255
    
hgs
parents:
diff changeset
  2256
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2257
hgs
parents:
diff changeset
  2258
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2259
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2260
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2261
hgs
parents:
diff changeset
  2262
    //Register all the desired applications
hgs
parents:
diff changeset
  2263
    RegisterApplicationsL(*iTmServer);    
hgs
parents:
diff changeset
  2264
    
hgs
parents:
diff changeset
  2265
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2266
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2267
    
hgs
parents:
diff changeset
  2268
    //Start the control point and search for device
hgs
parents:
diff changeset
  2269
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2270
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2271
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2272
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2273
hgs
parents:
diff changeset
  2274
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2275
        {
hgs
parents:
diff changeset
  2276
         //Retrieve the list of applications
hgs
parents:
diff changeset
  2277
         iSearchDevice->GetAppListActionL( KWildCard(),KProfileIdValue);
hgs
parents:
diff changeset
  2278
        }
hgs
parents:
diff changeset
  2279
    
hgs
parents:
diff changeset
  2280
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2281
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2282
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  2283
    if (iGetAppList)
hgs
parents:
diff changeset
  2284
        {
hgs
parents:
diff changeset
  2285
        _LIT( KDescription , "GetAppList Command With No Filter handled successfully");
hgs
parents:
diff changeset
  2286
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2287
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2288
        }
hgs
parents:
diff changeset
  2289
    else
hgs
parents:
diff changeset
  2290
        {
hgs
parents:
diff changeset
  2291
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2292
        _LIT( KDescription , "GetAppList Command With No Filter handling Failed");
hgs
parents:
diff changeset
  2293
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2294
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2295
        }
hgs
parents:
diff changeset
  2296
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2297
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2298
    delete iTestTimer;
hgs
parents:
diff changeset
  2299
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2300
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2301
    return KErrNone;
hgs
parents:
diff changeset
  2302
    }
hgs
parents:
diff changeset
  2303
hgs
parents:
diff changeset
  2304
TInt CTmServerTest::HandleInvalidProfileIdGetAppListActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  2305
    {
hgs
parents:
diff changeset
  2306
    _LIT( KLogInfo, "Handle Invalid ProfileId GetAppList Command" );
hgs
parents:
diff changeset
  2307
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2308
    
hgs
parents:
diff changeset
  2309
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2310
hgs
parents:
diff changeset
  2311
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2312
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2313
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this );
hgs
parents:
diff changeset
  2314
    
hgs
parents:
diff changeset
  2315
    //Register all the desired applications
hgs
parents:
diff changeset
  2316
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
  2317
    
hgs
parents:
diff changeset
  2318
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2319
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2320
    
hgs
parents:
diff changeset
  2321
    //Start the control point and search for device
hgs
parents:
diff changeset
  2322
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2323
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2324
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2325
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2326
    
hgs
parents:
diff changeset
  2327
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2328
        {
hgs
parents:
diff changeset
  2329
         //Retrieve the list of applications by specifying invalid profileId
hgs
parents:
diff changeset
  2330
         iSearchDevice->GetAppListActionL(KWildCard(),KInvalidProfileIdValue);
hgs
parents:
diff changeset
  2331
        }
hgs
parents:
diff changeset
  2332
    
hgs
parents:
diff changeset
  2333
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2334
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2335
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  2336
    if (iGetAppList)
hgs
parents:
diff changeset
  2337
        {
hgs
parents:
diff changeset
  2338
        _LIT( KDescription , "GetAppList Command with invalid ProfileId handled successfully");
hgs
parents:
diff changeset
  2339
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2340
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2341
        }
hgs
parents:
diff changeset
  2342
    else
hgs
parents:
diff changeset
  2343
        {
hgs
parents:
diff changeset
  2344
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2345
        _LIT( KDescription , "GetAppList Command with invalid ProfileId  handling Failed");
hgs
parents:
diff changeset
  2346
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2347
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2348
        }
hgs
parents:
diff changeset
  2349
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2350
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2351
    delete iTestTimer;
hgs
parents:
diff changeset
  2352
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2353
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2354
    return KErrNone;
hgs
parents:
diff changeset
  2355
    }
hgs
parents:
diff changeset
  2356
hgs
parents:
diff changeset
  2357
TInt CTmServerTest::HandleGetAppListActionOperationRejectedL ( TTestResult& aResult )
hgs
parents:
diff changeset
  2358
    {
hgs
parents:
diff changeset
  2359
    _LIT( KLogInfo, "Handle Operation Rejected Condition For GetAppList Command" );
hgs
parents:
diff changeset
  2360
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2361
    
hgs
parents:
diff changeset
  2362
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2363
hgs
parents:
diff changeset
  2364
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2365
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2366
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this );
hgs
parents:
diff changeset
  2367
    
hgs
parents:
diff changeset
  2368
    //Register all the desired applications
hgs
parents:
diff changeset
  2369
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
  2370
    
hgs
parents:
diff changeset
  2371
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2372
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2373
    iOperationRejected = ETrue; 
hgs
parents:
diff changeset
  2374
    //Start the control point and search for device
hgs
parents:
diff changeset
  2375
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2376
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2377
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2378
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2379
    
hgs
parents:
diff changeset
  2380
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2381
        {
hgs
parents:
diff changeset
  2382
         //Retrieve the list of applications by specifying profileId
hgs
parents:
diff changeset
  2383
         iSearchDevice->GetAppListActionL(KAppListFilterValue1(),KProfileIdValue);
hgs
parents:
diff changeset
  2384
        }
hgs
parents:
diff changeset
  2385
    
hgs
parents:
diff changeset
  2386
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2387
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2388
    CActiveScheduler::Start();      
hgs
parents:
diff changeset
  2389
    if (iGetAppList)
hgs
parents:
diff changeset
  2390
        {
hgs
parents:
diff changeset
  2391
        _LIT( KDescription , "Handle Operation Rejected Condition For GetAppList Command handled successfully");
hgs
parents:
diff changeset
  2392
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2393
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2394
        }
hgs
parents:
diff changeset
  2395
    else
hgs
parents:
diff changeset
  2396
        {
hgs
parents:
diff changeset
  2397
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2398
        _LIT( KDescription , "Handle Operation Rejected Condition For GetAppList Command handling Failed");
hgs
parents:
diff changeset
  2399
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2400
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2401
        }
hgs
parents:
diff changeset
  2402
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2403
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2404
    delete iTestTimer;
hgs
parents:
diff changeset
  2405
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2406
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2407
    return KErrNone;
hgs
parents:
diff changeset
  2408
    }
hgs
parents:
diff changeset
  2409
hgs
parents:
diff changeset
  2410
TInt CTmServerTest::HandleSetClientProfileActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  2411
    {
hgs
parents:
diff changeset
  2412
    _LIT( KLogInfo, "Handle SetClientProfile Command" );
hgs
parents:
diff changeset
  2413
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2414
    
hgs
parents:
diff changeset
  2415
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2416
hgs
parents:
diff changeset
  2417
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2418
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2419
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2420
hgs
parents:
diff changeset
  2421
    //Register all the desired applications
hgs
parents:
diff changeset
  2422
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
  2423
    
hgs
parents:
diff changeset
  2424
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2425
    iTmServer->StartL(); 
hgs
parents:
diff changeset
  2426
    
hgs
parents:
diff changeset
  2427
    //Start the control point and search for device
hgs
parents:
diff changeset
  2428
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2429
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2430
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2431
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2432
hgs
parents:
diff changeset
  2433
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2434
        {
hgs
parents:
diff changeset
  2435
         // Register the client profile 
hgs
parents:
diff changeset
  2436
         iSearchDevice->SetClientProfileActionL(KProfileIdValue, KClientProfileInfo);
hgs
parents:
diff changeset
  2437
        }
hgs
parents:
diff changeset
  2438
    
hgs
parents:
diff changeset
  2439
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2440
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2441
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  2442
    
hgs
parents:
diff changeset
  2443
    if (iSetClientProfile)
hgs
parents:
diff changeset
  2444
        {
hgs
parents:
diff changeset
  2445
        _LIT( KDescription , "SetClientProfile Command handled successfully");
hgs
parents:
diff changeset
  2446
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2447
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2448
        }
hgs
parents:
diff changeset
  2449
    else
hgs
parents:
diff changeset
  2450
        {
hgs
parents:
diff changeset
  2451
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2452
        _LIT( KDescription , "SetClientProfile Command handling  Failed");
hgs
parents:
diff changeset
  2453
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2454
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2455
        }
hgs
parents:
diff changeset
  2456
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2457
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2458
    delete iTestTimer;
hgs
parents:
diff changeset
  2459
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2460
    iClientIconPrefArray.ResetAndDestroy();
hgs
parents:
diff changeset
  2461
    iClientIconPrefArray.Close();
hgs
parents:
diff changeset
  2462
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2463
    return KErrNone;
hgs
parents:
diff changeset
  2464
    }
hgs
parents:
diff changeset
  2465
hgs
parents:
diff changeset
  2466
TInt CTmServerTest::HandleInvalidProfileIdSetClientProfileActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  2467
    {
hgs
parents:
diff changeset
  2468
    _LIT( KLogInfo, "Handle Invalid ProfileId SetClientProfile Command" );
hgs
parents:
diff changeset
  2469
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2470
    
hgs
parents:
diff changeset
  2471
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2472
hgs
parents:
diff changeset
  2473
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2474
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2475
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2476
hgs
parents:
diff changeset
  2477
    //Register all the desired applications
hgs
parents:
diff changeset
  2478
    RegisterApplicationsL(*iTmServer);    
hgs
parents:
diff changeset
  2479
    
hgs
parents:
diff changeset
  2480
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2481
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2482
hgs
parents:
diff changeset
  2483
    //Start the control point and search for device
hgs
parents:
diff changeset
  2484
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2485
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2486
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2487
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2488
hgs
parents:
diff changeset
  2489
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2490
        {
hgs
parents:
diff changeset
  2491
         //Register the client profile with invalid profileId
hgs
parents:
diff changeset
  2492
         iSearchDevice->SetClientProfileActionL(KInvalidProfileIdValue, KClientProfileInfo );
hgs
parents:
diff changeset
  2493
        }
hgs
parents:
diff changeset
  2494
    
hgs
parents:
diff changeset
  2495
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2496
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2497
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  2498
    
hgs
parents:
diff changeset
  2499
    if (iSetClientProfile)
hgs
parents:
diff changeset
  2500
        {
hgs
parents:
diff changeset
  2501
        _LIT( KDescription , "SetClientProfile Command with invalid ProfileId handled successfully");
hgs
parents:
diff changeset
  2502
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2503
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2504
        }
hgs
parents:
diff changeset
  2505
    else
hgs
parents:
diff changeset
  2506
        {
hgs
parents:
diff changeset
  2507
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2508
        _LIT( KDescription , "SetClientProfile Command with invalid ProfileId handling Failed");
hgs
parents:
diff changeset
  2509
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2510
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2511
        }
hgs
parents:
diff changeset
  2512
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2513
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2514
    delete iTestTimer;
hgs
parents:
diff changeset
  2515
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2516
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2517
    return KErrNone;
hgs
parents:
diff changeset
  2518
    }
hgs
parents:
diff changeset
  2519
hgs
parents:
diff changeset
  2520
TInt CTmServerTest::HandleInvalidProfileSetClientProfileActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  2521
    {
hgs
parents:
diff changeset
  2522
    _LIT( KLogInfo, "Handle Invalid Profile SetClientProfile Command" );
hgs
parents:
diff changeset
  2523
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2524
    
hgs
parents:
diff changeset
  2525
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2526
hgs
parents:
diff changeset
  2527
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2528
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2529
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2530
    
hgs
parents:
diff changeset
  2531
    //Register all the desired applications
hgs
parents:
diff changeset
  2532
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
  2533
    
hgs
parents:
diff changeset
  2534
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2535
    iTmServer->StartL();
hgs
parents:
diff changeset
  2536
    
hgs
parents:
diff changeset
  2537
    //Start the control point and search for device
hgs
parents:
diff changeset
  2538
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2539
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2540
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2541
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2542
hgs
parents:
diff changeset
  2543
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2544
        {
hgs
parents:
diff changeset
  2545
        _LIT8(KInvalidProfile,"&lt;clientProfile");
hgs
parents:
diff changeset
  2546
        //Register the client profile with invalid profile
hgs
parents:
diff changeset
  2547
        iSearchDevice->SetClientProfileActionL(KProfileIdValue, KInvalidProfile());
hgs
parents:
diff changeset
  2548
        }
hgs
parents:
diff changeset
  2549
    
hgs
parents:
diff changeset
  2550
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2551
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2552
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  2553
    
hgs
parents:
diff changeset
  2554
    if (iSetClientProfile)
hgs
parents:
diff changeset
  2555
        {
hgs
parents:
diff changeset
  2556
        _LIT( KDescription , "SetClientProfile Command with invalid Profile handled successfully");
hgs
parents:
diff changeset
  2557
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2558
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2559
        }
hgs
parents:
diff changeset
  2560
    else
hgs
parents:
diff changeset
  2561
        {
hgs
parents:
diff changeset
  2562
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2563
        _LIT( KDescription , "SetClientProfile Command with invalid Profile handling Failed");
hgs
parents:
diff changeset
  2564
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2565
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2566
        }
hgs
parents:
diff changeset
  2567
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2568
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2569
    delete iTestTimer;
hgs
parents:
diff changeset
  2570
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2571
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2572
    return KErrNone;
hgs
parents:
diff changeset
  2573
    }
hgs
parents:
diff changeset
  2574
hgs
parents:
diff changeset
  2575
TInt CTmServerTest::HandleDeviceLockedSetClientProfileActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  2576
    {
hgs
parents:
diff changeset
  2577
    _LIT( KLogInfo, "Handle Device Locked Condition For SetClientProfile Command" );
hgs
parents:
diff changeset
  2578
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2579
    
hgs
parents:
diff changeset
  2580
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2581
hgs
parents:
diff changeset
  2582
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2583
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2584
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2585
    
hgs
parents:
diff changeset
  2586
    //Register all the desired applications
hgs
parents:
diff changeset
  2587
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
  2588
    
hgs
parents:
diff changeset
  2589
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2590
    iTmServer->StartL();
hgs
parents:
diff changeset
  2591
    
hgs
parents:
diff changeset
  2592
    //Start the control point and search for device
hgs
parents:
diff changeset
  2593
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2594
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2595
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2596
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2597
hgs
parents:
diff changeset
  2598
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2599
        {
hgs
parents:
diff changeset
  2600
        //Register the client profile 
hgs
parents:
diff changeset
  2601
        iSearchDevice->SetClientProfileActionL(KProfileIdValue, KDeviceLockedClientProfile());
hgs
parents:
diff changeset
  2602
        }
hgs
parents:
diff changeset
  2603
    
hgs
parents:
diff changeset
  2604
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2605
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2606
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  2607
    
hgs
parents:
diff changeset
  2608
    if (iSetClientProfile)
hgs
parents:
diff changeset
  2609
        {
hgs
parents:
diff changeset
  2610
        _LIT( KDescription , "Device Locked Condition for SetClientProfile Command handled successfully");
hgs
parents:
diff changeset
  2611
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2612
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2613
        }
hgs
parents:
diff changeset
  2614
    else
hgs
parents:
diff changeset
  2615
        {
hgs
parents:
diff changeset
  2616
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2617
        _LIT( KDescription , "Device Locked Condition for SetClientProfile Command handling Failed");
hgs
parents:
diff changeset
  2618
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2619
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2620
        }
hgs
parents:
diff changeset
  2621
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2622
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2623
    delete iTestTimer;
hgs
parents:
diff changeset
  2624
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2625
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2626
    return KErrNone;
hgs
parents:
diff changeset
  2627
    }
hgs
parents:
diff changeset
  2628
hgs
parents:
diff changeset
  2629
TInt CTmServerTest::HandleResourceBusySetClientProfileActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  2630
    {
hgs
parents:
diff changeset
  2631
    _LIT( KLogInfo, "Handle Resource Busy Condition For SetClientProfile Command" );
hgs
parents:
diff changeset
  2632
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2633
    
hgs
parents:
diff changeset
  2634
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2635
hgs
parents:
diff changeset
  2636
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2637
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2638
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2639
    
hgs
parents:
diff changeset
  2640
    //Register all the desired applications
hgs
parents:
diff changeset
  2641
    RegisterApplicationsL(*iTmServer); 
hgs
parents:
diff changeset
  2642
    
hgs
parents:
diff changeset
  2643
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2644
    iTmServer->StartL();
hgs
parents:
diff changeset
  2645
    iResourceBusy = ETrue;
hgs
parents:
diff changeset
  2646
    //Start the control point and search for device
hgs
parents:
diff changeset
  2647
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2648
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2649
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2650
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2651
hgs
parents:
diff changeset
  2652
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2653
        {
hgs
parents:
diff changeset
  2654
        //Register the client profile 
hgs
parents:
diff changeset
  2655
        iSearchDevice->SetClientProfileActionL(KProfileIdValue, KClientProfileInfo());
hgs
parents:
diff changeset
  2656
        }
hgs
parents:
diff changeset
  2657
    
hgs
parents:
diff changeset
  2658
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2659
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2660
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  2661
    
hgs
parents:
diff changeset
  2662
    if (iSetClientProfile)
hgs
parents:
diff changeset
  2663
        {
hgs
parents:
diff changeset
  2664
        _LIT( KDescription , "Resource Busy Condition for SetClientProfile Command handled successfully");
hgs
parents:
diff changeset
  2665
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2666
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2667
        }
hgs
parents:
diff changeset
  2668
    else
hgs
parents:
diff changeset
  2669
        {
hgs
parents:
diff changeset
  2670
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2671
        _LIT( KDescription , "Resource Busy Condition for SetClientProfile Command handling Failed");
hgs
parents:
diff changeset
  2672
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2673
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2674
        }
hgs
parents:
diff changeset
  2675
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2676
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2677
    delete iTestTimer;
hgs
parents:
diff changeset
  2678
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2679
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2680
    return KErrNone;
hgs
parents:
diff changeset
  2681
    }
hgs
parents:
diff changeset
  2682
hgs
parents:
diff changeset
  2683
TInt CTmServerTest::HandleGetClientProfileActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  2684
    {
hgs
parents:
diff changeset
  2685
    _LIT( KLogInfo, "Handle GetClientProfile Command" );
hgs
parents:
diff changeset
  2686
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2687
    
hgs
parents:
diff changeset
  2688
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2689
hgs
parents:
diff changeset
  2690
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2691
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2692
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2693
hgs
parents:
diff changeset
  2694
    //Register all the desired applications
hgs
parents:
diff changeset
  2695
    RegisterApplicationsL(*iTmServer);     
hgs
parents:
diff changeset
  2696
hgs
parents:
diff changeset
  2697
    //Start the tmserver device and its services
hgs
parents:
diff changeset
  2698
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2699
hgs
parents:
diff changeset
  2700
    //Start the control point and search for device
hgs
parents:
diff changeset
  2701
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2702
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2703
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2704
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2705
hgs
parents:
diff changeset
  2706
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2707
        {
hgs
parents:
diff changeset
  2708
         //Retrieve the contents of a client profile stored in the terminal mode device
hgs
parents:
diff changeset
  2709
         iSearchDevice->GetClientProfileActionL(KProfileIdValue);
hgs
parents:
diff changeset
  2710
        }
hgs
parents:
diff changeset
  2711
    
hgs
parents:
diff changeset
  2712
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2713
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2714
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  2715
    
hgs
parents:
diff changeset
  2716
    if (iGetClientProfile)
hgs
parents:
diff changeset
  2717
        {
hgs
parents:
diff changeset
  2718
        _LIT( KDescription , "GetClientProfile Command handled successfully");
hgs
parents:
diff changeset
  2719
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2720
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2721
        }
hgs
parents:
diff changeset
  2722
    else
hgs
parents:
diff changeset
  2723
        {
hgs
parents:
diff changeset
  2724
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2725
        _LIT( KDescription , "GetClientProfile Command handling  Failed");
hgs
parents:
diff changeset
  2726
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2727
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2728
        }
hgs
parents:
diff changeset
  2729
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2730
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2731
    delete iTestTimer;
hgs
parents:
diff changeset
  2732
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2733
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2734
    return KErrNone;
hgs
parents:
diff changeset
  2735
    }
hgs
parents:
diff changeset
  2736
hgs
parents:
diff changeset
  2737
TInt CTmServerTest::HandleInvalidProfileIdGetClientProfileActionL ( TTestResult& aResult )
hgs
parents:
diff changeset
  2738
    {
hgs
parents:
diff changeset
  2739
    _LIT( KLogInfo, "Handle Invalid ProfileId GetClientProfile Command" );
hgs
parents:
diff changeset
  2740
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2741
    
hgs
parents:
diff changeset
  2742
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2743
hgs
parents:
diff changeset
  2744
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2745
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2746
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2747
hgs
parents:
diff changeset
  2748
    //Register all the desired applications
hgs
parents:
diff changeset
  2749
    RegisterApplicationsL(*iTmServer);  
hgs
parents:
diff changeset
  2750
    
hgs
parents:
diff changeset
  2751
    //Start the control point and search for device
hgs
parents:
diff changeset
  2752
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2753
hgs
parents:
diff changeset
  2754
    //Start the control point and search for device
hgs
parents:
diff changeset
  2755
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2756
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2757
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2758
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2759
hgs
parents:
diff changeset
  2760
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2761
        {
hgs
parents:
diff changeset
  2762
         //Retrieve the contents of a client profile by specifying invalid profileId
hgs
parents:
diff changeset
  2763
         iSearchDevice->GetClientProfileActionL(KInvalidProfileIdValue);
hgs
parents:
diff changeset
  2764
        }
hgs
parents:
diff changeset
  2765
    
hgs
parents:
diff changeset
  2766
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2767
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2768
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  2769
    
hgs
parents:
diff changeset
  2770
    if (iGetClientProfile)
hgs
parents:
diff changeset
  2771
        {
hgs
parents:
diff changeset
  2772
        _LIT( KDescription , "GetClientProfile Command with invalid ProfileId handled successfully");
hgs
parents:
diff changeset
  2773
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2774
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2775
        }
hgs
parents:
diff changeset
  2776
    else
hgs
parents:
diff changeset
  2777
        {
hgs
parents:
diff changeset
  2778
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2779
        _LIT( KDescription , "GetClientProfile Command with invalid ProfileId handling Failed");
hgs
parents:
diff changeset
  2780
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2781
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2782
        }
hgs
parents:
diff changeset
  2783
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2784
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2785
    delete iTestTimer;
hgs
parents:
diff changeset
  2786
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2787
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2788
    return KErrNone;
hgs
parents:
diff changeset
  2789
    }
hgs
parents:
diff changeset
  2790
hgs
parents:
diff changeset
  2791
hgs
parents:
diff changeset
  2792
TInt CTmServerTest::HandleGetMaxNumProfilesActionL( TTestResult& aResult )
hgs
parents:
diff changeset
  2793
    {
hgs
parents:
diff changeset
  2794
    _LIT( KLogInfo, "Handle GetMaxNumProfiles Command" );
hgs
parents:
diff changeset
  2795
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2796
    
hgs
parents:
diff changeset
  2797
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2798
hgs
parents:
diff changeset
  2799
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2800
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2801
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2802
hgs
parents:
diff changeset
  2803
    //Register all the desired applications
hgs
parents:
diff changeset
  2804
    RegisterApplicationsL(*iTmServer);  
hgs
parents:
diff changeset
  2805
    
hgs
parents:
diff changeset
  2806
    //Start the control point and search for device
hgs
parents:
diff changeset
  2807
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2808
hgs
parents:
diff changeset
  2809
    //Start the control point and search for device
hgs
parents:
diff changeset
  2810
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2811
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2812
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2813
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2814
hgs
parents:
diff changeset
  2815
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2816
        {
hgs
parents:
diff changeset
  2817
         //Get the maximum number of client profiles supported
hgs
parents:
diff changeset
  2818
         iSearchDevice->GetMaxNumProfilesActionL();
hgs
parents:
diff changeset
  2819
        }
hgs
parents:
diff changeset
  2820
    
hgs
parents:
diff changeset
  2821
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2822
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2823
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  2824
    
hgs
parents:
diff changeset
  2825
    if (iGetMaxNumProfiles)
hgs
parents:
diff changeset
  2826
        {
hgs
parents:
diff changeset
  2827
        _LIT( KDescription , "GetMaxNumProfiles Command handled successfully");
hgs
parents:
diff changeset
  2828
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2829
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2830
        }
hgs
parents:
diff changeset
  2831
    else
hgs
parents:
diff changeset
  2832
        {
hgs
parents:
diff changeset
  2833
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2834
        _LIT( KDescription , "GetMaxNumProfiles Command handling  Failed");
hgs
parents:
diff changeset
  2835
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2836
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2837
        }
hgs
parents:
diff changeset
  2838
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2839
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2840
    delete iTestTimer;
hgs
parents:
diff changeset
  2841
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2842
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2843
    return KErrNone;
hgs
parents:
diff changeset
  2844
    }
hgs
parents:
diff changeset
  2845
hgs
parents:
diff changeset
  2846
TInt CTmServerTest::HandleGetMaxNumProfilesOperationRejectedL( TTestResult& aResult )
hgs
parents:
diff changeset
  2847
    {
hgs
parents:
diff changeset
  2848
    _LIT( KLogInfo, "Handle Operation Rejected Condition For GetMaxNumProfiles Command" );
hgs
parents:
diff changeset
  2849
    iLog->Log( KLogInfo );
hgs
parents:
diff changeset
  2850
    
hgs
parents:
diff changeset
  2851
    iTmServerDeviceType = ETrue;
hgs
parents:
diff changeset
  2852
hgs
parents:
diff changeset
  2853
    //Sets the information associated with the terminal mode server device
hgs
parents:
diff changeset
  2854
    SetTmServerSettingsL();
hgs
parents:
diff changeset
  2855
    iTmServer = CUpnpTmServer::NewL( *iTmServerDeviceInfo, *this ); 
hgs
parents:
diff changeset
  2856
hgs
parents:
diff changeset
  2857
    //Register all the desired applications
hgs
parents:
diff changeset
  2858
    RegisterApplicationsL(*iTmServer);  
hgs
parents:
diff changeset
  2859
    
hgs
parents:
diff changeset
  2860
    //Start the control point and search for device
hgs
parents:
diff changeset
  2861
    iTmServer->StartL();   
hgs
parents:
diff changeset
  2862
    iOperationRejected = ETrue; 
hgs
parents:
diff changeset
  2863
    //Start the control point and search for device
hgs
parents:
diff changeset
  2864
    iSearchDevice = CDiscoverDevice::NewL(*this);    
hgs
parents:
diff changeset
  2865
    iDiscoveryTestTimer = CDiscoveryTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2866
    iDiscoveryTestTimer->AfterDiscovery(15);
hgs
parents:
diff changeset
  2867
    CActiveScheduler::Start(); 
hgs
parents:
diff changeset
  2868
hgs
parents:
diff changeset
  2869
    if ( iDeviceVerified  )
hgs
parents:
diff changeset
  2870
        {
hgs
parents:
diff changeset
  2871
         //Get the maximum number of client profiles supported
hgs
parents:
diff changeset
  2872
         iSearchDevice->GetMaxNumProfilesActionL();
hgs
parents:
diff changeset
  2873
        }
hgs
parents:
diff changeset
  2874
    
hgs
parents:
diff changeset
  2875
    iTestTimer = CTestTimer::NewL(*this);
hgs
parents:
diff changeset
  2876
    iTestTimer->After(15);
hgs
parents:
diff changeset
  2877
    CActiveScheduler::Start();  
hgs
parents:
diff changeset
  2878
    
hgs
parents:
diff changeset
  2879
    if (iGetMaxNumProfiles)
hgs
parents:
diff changeset
  2880
        {
hgs
parents:
diff changeset
  2881
        _LIT( KDescription , "Operation Rejected Condition For GetMaxNumProfiles Command handled successfully");
hgs
parents:
diff changeset
  2882
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2883
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2884
        }
hgs
parents:
diff changeset
  2885
    else
hgs
parents:
diff changeset
  2886
        {
hgs
parents:
diff changeset
  2887
        aResult.iResult = KErrGeneral;
hgs
parents:
diff changeset
  2888
        _LIT( KDescription , "Operation Rejected Condition For GetMaxNumProfiles Command handling  Failed");
hgs
parents:
diff changeset
  2889
        aResult.SetResult( KErrNone, KDescription );
hgs
parents:
diff changeset
  2890
        iLog->Log( KDescription );
hgs
parents:
diff changeset
  2891
        }
hgs
parents:
diff changeset
  2892
    delete iDiscoveryTestTimer;
hgs
parents:
diff changeset
  2893
    iDiscoveryTestTimer = NULL;
hgs
parents:
diff changeset
  2894
    delete iTestTimer;
hgs
parents:
diff changeset
  2895
    iTestTimer = NULL;
hgs
parents:
diff changeset
  2896
    REComSession::FinalClose();
hgs
parents:
diff changeset
  2897
    return KErrNone;
hgs
parents:
diff changeset
  2898
    }
hgs
parents:
diff changeset
  2899
hgs
parents:
diff changeset
  2900
// ========================================================================================================
hgs
parents:
diff changeset
  2901
hgs
parents:
diff changeset
  2902
void CTmServerTest::SetTmServerSettingsL()
hgs
parents:
diff changeset
  2903
    { 
hgs
parents:
diff changeset
  2904
    iTmServerDeviceInfo = CUpnpTmServerDeviceInfo::NewL(CUpnpSettings::GetIapL());  
hgs
parents:
diff changeset
  2905
    iTmServerDeviceInfo->SetDeviceInfoL( KDeviceInfo );
hgs
parents:
diff changeset
  2906
    iTmServerDeviceInfo->SetBtAddressL( KBtMacValue );
hgs
parents:
diff changeset
  2907
    iTmServerDeviceInfo->SetStartConn(ETrue);
hgs
parents:
diff changeset
  2908
    iTmServerDeviceInfo->AddDeviceIconL(CUpnpTerminalModeIcon::NewL(KIconDevicePath, KIconWidth, KIconHeight, KIconDepth,KTestSvgMimeType));
hgs
parents:
diff changeset
  2909
    }
hgs
parents:
diff changeset
  2910
hgs
parents:
diff changeset
  2911
void CTmServerTest::RegisterApplicationsL(CUpnpTmServer& aTmServer )
hgs
parents:
diff changeset
  2912
    {  
hgs
parents:
diff changeset
  2913
    RArray<TUint> allowedProfileIdList;
hgs
parents:
diff changeset
  2914
    allowedProfileIdList.Append(0);
hgs
parents:
diff changeset
  2915
    allowedProfileIdList.Append(1);
hgs
parents:
diff changeset
  2916
    allowedProfileIdList.Append(2);
hgs
parents:
diff changeset
  2917
    allowedProfileIdList.Append(2);
hgs
parents:
diff changeset
  2918
    allowedProfileIdList.Append(3);
hgs
parents:
diff changeset
  2919
    allowedProfileIdList.Append(4);
hgs
parents:
diff changeset
  2920
    allowedProfileIdList.Append(5);
hgs
parents:
diff changeset
  2921
    allowedProfileIdList.Append(6);
hgs
parents:
diff changeset
  2922
hgs
parents:
diff changeset
  2923
    _LIT8(KAppDesc, "Mobile Navigation Application");
hgs
parents:
diff changeset
  2924
    iRemotableApp = CUpnpRemotableApp::NewL( KAppIdValue ,_L8("Navigation"));  
hgs
parents:
diff changeset
  2925
    iRemotableApp->SetAppDescriptionL(KAppDesc());
hgs
parents:
diff changeset
  2926
    iRemotableApp->SetAllowedProfileIdListL(allowedProfileIdList);   
hgs
parents:
diff changeset
  2927
    CUpnpTmInfoElement& tmInfoElement = iRemotableApp->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
  2928
    tmInfoElement.AddTmInfoElementL(_L8("protocolID"),_L8("VNC"));
hgs
parents:
diff changeset
  2929
    
hgs
parents:
diff changeset
  2930
    CUpnpTmInfoElement& tmInfoElement1 = iRemotableApp->CreateTmInfoElementL(CUpnpTmInfoElement::EAppInfo);
hgs
parents:
diff changeset
  2931
    tmInfoElement1.AddTmInfoElementL(_L8("appCategory"),_L8("0x00010001"));
hgs
parents:
diff changeset
  2932
    tmInfoElement1.AddTmInfoElementL(_L8("trustLevel"),_L8("0x80"));
hgs
parents:
diff changeset
  2933
    
hgs
parents:
diff changeset
  2934
    CUpnpTmInfoElement& tmInfoElement2 = iRemotableApp->CreateTmInfoElementL(CUpnpTmInfoElement::EDisplayInfo);
hgs
parents:
diff changeset
  2935
    tmInfoElement2.AddTmInfoElementL(_L8("contentCategory"),_L8("0x0000001"));
hgs
parents:
diff changeset
  2936
    tmInfoElement2.AddTmInfoElementL(_L8("contentRules"),_L8("0x00000FE"));
hgs
parents:
diff changeset
  2937
    tmInfoElement2.AddTmInfoElementL(_L8("trustLevel"),_L8("0x00000001"));
hgs
parents:
diff changeset
  2938
    iRemotableApp->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathMaps, KIconWidth1, KIconHeight1, KIconDepth,KTestSvgMimeType));
hgs
parents:
diff changeset
  2939
    aTmServer.RegisterAppL(iRemotableApp);   
hgs
parents:
diff changeset
  2940
    allowedProfileIdList.Close();
hgs
parents:
diff changeset
  2941
   
hgs
parents:
diff changeset
  2942
    _LIT8(KAppDesc1, "RTP Audio Server");
hgs
parents:
diff changeset
  2943
    iRemotableApp1 = CUpnpRemotableApp::NewL( KAppId1Value ,_L8("RTP Server"));
hgs
parents:
diff changeset
  2944
    iRemotableApp1->SetAppDescriptionL(KAppDesc1());
hgs
parents:
diff changeset
  2945
    
hgs
parents:
diff changeset
  2946
    CUpnpTmInfoElement& tmInfoElement3 = iRemotableApp1->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
  2947
    tmInfoElement3.AddTmInfoElementL(_L8("protocolID"),_L8("RTP"));
hgs
parents:
diff changeset
  2948
    tmInfoElement3.AddTmInfoElementL(_L8("format"),_L8("99"));
hgs
parents:
diff changeset
  2949
    tmInfoElement3.AddTmInfoElementL(_L8("direction"),_L8("out"));
hgs
parents:
diff changeset
  2950
    
hgs
parents:
diff changeset
  2951
    CUpnpTmInfoElement& tmInfoElement4 = iRemotableApp1->CreateTmInfoElementL(CUpnpTmInfoElement::EAppInfo);
hgs
parents:
diff changeset
  2952
    tmInfoElement4.AddTmInfoElementL(_L8("appCategory"),_L8("0x0000002"));
hgs
parents:
diff changeset
  2953
    tmInfoElement4.AddTmInfoElementL(_L8("trustLevel"),_L8("0x00000001"));
hgs
parents:
diff changeset
  2954
    
hgs
parents:
diff changeset
  2955
    CUpnpTmInfoElement& tmInfoElement5 = iRemotableApp1->CreateTmInfoElementL(CUpnpTmInfoElement::EAudioInfo);
hgs
parents:
diff changeset
  2956
    tmInfoElement5.AddTmInfoElementL(_L8("audioType"),_L8("all"));    
hgs
parents:
diff changeset
  2957
    iRemotableApp1->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathMusicUnLaunched,KIconWidth, KIconHeight, KIconDepth,KTestSvgMimeType));
hgs
parents:
diff changeset
  2958
    iRemotableApp1->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathMusicLaunched,KIconWidth, KIconHeight, KIconDepth,KTestSvgMimeType));
hgs
parents:
diff changeset
  2959
    iRemotableApp1->SetResourceStatusL(_L8("free"));
hgs
parents:
diff changeset
  2960
   
hgs
parents:
diff changeset
  2961
    iRemotableAppArray.AppendL(iRemotableApp1);      
hgs
parents:
diff changeset
  2962
hgs
parents:
diff changeset
  2963
    _LIT8(KAppDesc2, "Bluetooth A2DP Audio Server");
hgs
parents:
diff changeset
  2964
    iRemotableApp2 = CUpnpRemotableApp::NewL( KAppId2Value ,_L8("Bluetooth A2DP"));
hgs
parents:
diff changeset
  2965
    iRemotableApp2->SetAppDescriptionL(KAppDesc2());
hgs
parents:
diff changeset
  2966
    
hgs
parents:
diff changeset
  2967
    CUpnpTmInfoElement& tmInfoElement6 = iRemotableApp2->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
  2968
    tmInfoElement6.AddTmInfoElementL(_L8("protocolID"),_L8("BTA2DP"));
hgs
parents:
diff changeset
  2969
    tmInfoElement6.AddTmInfoElementL(_L8("direction"),_L8("out"));
hgs
parents:
diff changeset
  2970
    
hgs
parents:
diff changeset
  2971
    CUpnpTmInfoElement& tmInfoElement7 = iRemotableApp2->CreateTmInfoElementL(CUpnpTmInfoElement::EAppInfo);
hgs
parents:
diff changeset
  2972
    tmInfoElement7.AddTmInfoElementL(_L8("appCategory"),_L8("0x0000003"));
hgs
parents:
diff changeset
  2973
    tmInfoElement7.AddTmInfoElementL(_L8("trustLevel"),_L8("0x00000001"));
hgs
parents:
diff changeset
  2974
    
hgs
parents:
diff changeset
  2975
    iRemotableApp2->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathBtA2DpUnLaunched, KIconWidth2, KIconHeight2, KIconDepth1,KTestSvgMimeType)); 
hgs
parents:
diff changeset
  2976
    iRemotableApp2->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathBtA2DpLaunched,KIconWidth3, KIconHeight3, KIconDepth1,KTestSvgMimeType));
hgs
parents:
diff changeset
  2977
    iRemotableApp2->SetResourceStatusL(_L8("free"));
hgs
parents:
diff changeset
  2978
    iRemotableAppArray.AppendL(iRemotableApp2);      
hgs
parents:
diff changeset
  2979
    
hgs
parents:
diff changeset
  2980
     _LIT8(KAppDesc3, "Bluetooth HFP Audio");
hgs
parents:
diff changeset
  2981
    RArray<TUint> allowedProfileIdList1;
hgs
parents:
diff changeset
  2982
    allowedProfileIdList1.Append(0);
hgs
parents:
diff changeset
  2983
    iRemotableApp3 = CUpnpRemotableApp::NewL( KAppId3Value,_L8("Bluetooth HFP"));
hgs
parents:
diff changeset
  2984
    iRemotableApp3->SetAppDescriptionL(KAppDesc3());
hgs
parents:
diff changeset
  2985
    iRemotableApp3->SetAllowedProfileIdListL(allowedProfileIdList1);
hgs
parents:
diff changeset
  2986
    
hgs
parents:
diff changeset
  2987
    CUpnpTmInfoElement& tmInfoElement8 = iRemotableApp3->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
  2988
    tmInfoElement8.AddTmInfoElementL(_L8("protocolID"),_L8("BTHFP"));
hgs
parents:
diff changeset
  2989
    tmInfoElement8.AddTmInfoElementL(_L8("direction"),_L8("bi"));
hgs
parents:
diff changeset
  2990
    
hgs
parents:
diff changeset
  2991
    CUpnpTmInfoElement& tmInfoElement9 = iRemotableApp3->CreateTmInfoElementL(CUpnpTmInfoElement::EAppInfo);
hgs
parents:
diff changeset
  2992
    tmInfoElement9.AddTmInfoElementL(_L8("appCategory"),_L8("0x0000004"));
hgs
parents:
diff changeset
  2993
    tmInfoElement9.AddTmInfoElementL(_L8("trustLevel"),_L8("0x00000001")); 
hgs
parents:
diff changeset
  2994
   
hgs
parents:
diff changeset
  2995
    iRemotableApp3->AddIconL(CUpnpTerminalModeIcon::NewL(KIconPathBtHfp, KIconWidth, KIconHeight, KIconDepth,KTestSvgMimeType)); 
hgs
parents:
diff changeset
  2996
    iRemotableApp3->SetResourceStatusL(_L8("busy"));    
hgs
parents:
diff changeset
  2997
    iRemotableAppArray.AppendL(iRemotableApp3);     
hgs
parents:
diff changeset
  2998
    allowedProfileIdList1.Close();
hgs
parents:
diff changeset
  2999
    
hgs
parents:
diff changeset
  3000
    _LIT8(KAppDesc4, "Device Attestation Protocol");
hgs
parents:
diff changeset
  3001
    iRemotableApp4 = CUpnpRemotableApp::NewL( KAppId4Value ,_L8("Device Attestation"));
hgs
parents:
diff changeset
  3002
    iRemotableApp4->SetAppDescriptionL(KAppDesc4());
hgs
parents:
diff changeset
  3003
       
hgs
parents:
diff changeset
  3004
    CUpnpTmInfoElement& tmInfoElement11 = iRemotableApp4->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
  3005
    tmInfoElement11.AddTmInfoElementL(_L8("protocolID"),_L8("DAP")); 
hgs
parents:
diff changeset
  3006
    iRemotableAppArray.AppendL(iRemotableApp4); 
hgs
parents:
diff changeset
  3007
hgs
parents:
diff changeset
  3008
    iRemotableApp5 = CUpnpRemotableApp::NewL( KAppId5Value ,_L8("Device Attestation"));
hgs
parents:
diff changeset
  3009
    iRemotableApp5->SetAppDescriptionL(KAppDesc4());
hgs
parents:
diff changeset
  3010
hgs
parents:
diff changeset
  3011
    RArray<TUint> allowedProfileIdList2;
hgs
parents:
diff changeset
  3012
    allowedProfileIdList2.Append(1);    
hgs
parents:
diff changeset
  3013
    allowedProfileIdList2.Append(1);
hgs
parents:
diff changeset
  3014
    iRemotableApp5->SetAllowedProfileIdListL(allowedProfileIdList2);
hgs
parents:
diff changeset
  3015
       
hgs
parents:
diff changeset
  3016
    CUpnpTmInfoElement& tmInfoElement12 = iRemotableApp5->CreateTmInfoElementL(CUpnpTmInfoElement::ERemotingInfo);
hgs
parents:
diff changeset
  3017
    tmInfoElement12.AddTmInfoElementL(_L8("protocolID"),_L8("DAP")); 
hgs
parents:
diff changeset
  3018
    iRemotableAppArray.AppendL(iRemotableApp5);   
hgs
parents:
diff changeset
  3019
    allowedProfileIdList2.Close();
hgs
parents:
diff changeset
  3020
    
hgs
parents:
diff changeset
  3021
    aTmServer.SetXmlSignatureL(KXmlSignature);    
hgs
parents:
diff changeset
  3022
    aTmServer.RegisterAppsL(iRemotableAppArray); 
hgs
parents:
diff changeset
  3023
    iRemotableAppArray.Close();
hgs
parents:
diff changeset
  3024
    }
hgs
parents:
diff changeset
  3025
hgs
parents:
diff changeset
  3026
void CTmServerTest::TestTimerTimedOutL()
hgs
parents:
diff changeset
  3027
    {
hgs
parents:
diff changeset
  3028
    iTmServer->StopL();
hgs
parents:
diff changeset
  3029
    delete iSearchDevice;
hgs
parents:
diff changeset
  3030
    iSearchDevice = NULL;
hgs
parents:
diff changeset
  3031
    delete iTmServer;
hgs
parents:
diff changeset
  3032
    iTmServer = NULL;
hgs
parents:
diff changeset
  3033
    delete iTmServerDeviceInfo;
hgs
parents:
diff changeset
  3034
    iTmServerDeviceInfo = NULL;   
hgs
parents:
diff changeset
  3035
    CActiveScheduler::Stop();
hgs
parents:
diff changeset
  3036
    }
hgs
parents:
diff changeset
  3037
hgs
parents:
diff changeset
  3038
void CTmServerTest::TestTimerDiscoveryTimedOut()
hgs
parents:
diff changeset
  3039
    {
hgs
parents:
diff changeset
  3040
    CActiveScheduler::Stop();
hgs
parents:
diff changeset
  3041
    }
hgs
parents:
diff changeset
  3042
hgs
parents:
diff changeset
  3043
void CTmServerTest::DeviceVerified()
hgs
parents:
diff changeset
  3044
    {
hgs
parents:
diff changeset
  3045
    iDeviceVerified = ETrue;
hgs
parents:
diff changeset
  3046
    }
hgs
parents:
diff changeset
  3047
hgs
parents:
diff changeset
  3048
void CTmServerTest::DeviceLostVerified()
hgs
parents:
diff changeset
  3049
    {
hgs
parents:
diff changeset
  3050
    iDeviceLostVerified = ETrue;
hgs
parents:
diff changeset
  3051
    }
hgs
parents:
diff changeset
  3052
hgs
parents:
diff changeset
  3053
void CTmServerTest::ServiceVerified()
hgs
parents:
diff changeset
  3054
    {
hgs
parents:
diff changeset
  3055
    iServiceVerified = ETrue;
hgs
parents:
diff changeset
  3056
    }
hgs
parents:
diff changeset
  3057
hgs
parents:
diff changeset
  3058
CDiscoverDevice* CDiscoverDevice::NewL(CTmServerTest& aTmServerTest)
hgs
parents:
diff changeset
  3059
    {
hgs
parents:
diff changeset
  3060
    CDiscoverDevice* self = new (ELeave) CDiscoverDevice(aTmServerTest);
hgs
parents:
diff changeset
  3061
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
  3062
    self->ConstructL();
hgs
parents:
diff changeset
  3063
    CleanupStack::Pop( self );
hgs
parents:
diff changeset
  3064
    return self;
hgs
parents:
diff changeset
  3065
    }
hgs
parents:
diff changeset
  3066
hgs
parents:
diff changeset
  3067
CDiscoverDevice::CDiscoverDevice(CTmServerTest& aTmServerTest):
hgs
parents:
diff changeset
  3068
    iTmServerTest(aTmServerTest)
hgs
parents:
diff changeset
  3069
    {
hgs
parents:
diff changeset
  3070
    
hgs
parents:
diff changeset
  3071
    }
hgs
parents:
diff changeset
  3072
hgs
parents:
diff changeset
  3073
void CDiscoverDevice::ConstructL()
hgs
parents:
diff changeset
  3074
    {
hgs
parents:
diff changeset
  3075
    CDesC8ArrayFlat* targetDeviceTypes = new (ELeave) CDesC8ArrayFlat( 1 );
hgs
parents:
diff changeset
  3076
    CleanupStack::PushL( targetDeviceTypes ); 
hgs
parents:
diff changeset
  3077
    targetDeviceTypes->AppendL( KTmServerDevice() );    
hgs
parents:
diff changeset
  3078
    CUpnpControlPoint::ConstructL( *targetDeviceTypes );
hgs
parents:
diff changeset
  3079
    CleanupStack::Pop( targetDeviceTypes );
hgs
parents:
diff changeset
  3080
    targetDeviceTypes->Reset();
hgs
parents:
diff changeset
  3081
    delete targetDeviceTypes;
hgs
parents:
diff changeset
  3082
    targetDeviceTypes = NULL;
hgs
parents:
diff changeset
  3083
hgs
parents:
diff changeset
  3084
    //SSDP search for Terminalmode server devices
hgs
parents:
diff changeset
  3085
    if (iTmServerTest.iTmServerDeviceType)
hgs
parents:
diff changeset
  3086
         {
hgs
parents:
diff changeset
  3087
          SearchL( KTmServerDevice() );
hgs
parents:
diff changeset
  3088
          }
hgs
parents:
diff changeset
  3089
    else if (iTmServerTest.iTmServerServiceType)
hgs
parents:
diff changeset
  3090
          {
hgs
parents:
diff changeset
  3091
          SearchL( KTmServerService() );
hgs
parents:
diff changeset
  3092
          }   
hgs
parents:
diff changeset
  3093
     }
hgs
parents:
diff changeset
  3094
hgs
parents:
diff changeset
  3095
CDiscoverDevice::~CDiscoverDevice()
hgs
parents:
diff changeset
  3096
    {   
hgs
parents:
diff changeset
  3097
hgs
parents:
diff changeset
  3098
    }
hgs
parents:
diff changeset
  3099
hgs
parents:
diff changeset
  3100
hgs
parents:
diff changeset
  3101
void CDiscoverDevice::StateUpdatedL( CUpnpService* aService )
hgs
parents:
diff changeset
  3102
    {
hgs
parents:
diff changeset
  3103
    CUpnpDevice& device = aService->Device();
hgs
parents:
diff changeset
  3104
    if (aService->ServiceType().Match( KTmServerServiceType ) != KErrNotFound )
hgs
parents:
diff changeset
  3105
        {
hgs
parents:
diff changeset
  3106
        TInt err =  TmServerStateUpdated( device, aService );
hgs
parents:
diff changeset
  3107
        }
hgs
parents:
diff changeset
  3108
    else
hgs
parents:
diff changeset
  3109
        {
hgs
parents:
diff changeset
  3110
        User::Leave(KErrGeneral);
hgs
parents:
diff changeset
  3111
        }
hgs
parents:
diff changeset
  3112
    }
hgs
parents:
diff changeset
  3113
hgs
parents:
diff changeset
  3114
TInt CDiscoverDevice::TmServerStateUpdated( CUpnpDevice& aDevice,
hgs
parents:
diff changeset
  3115
                                                        CUpnpService*& aService )
hgs
parents:
diff changeset
  3116
    {
hgs
parents:
diff changeset
  3117
    CUpnpStateVariable* appStatusUpdate = aService->StateVariable( KArgTypeAppStatusUpdate );
hgs
parents:
diff changeset
  3118
    if( !appStatusUpdate )
hgs
parents:
diff changeset
  3119
        {
hgs
parents:
diff changeset
  3120
        iTmServerTest.iStatusNotified = EFalse;
hgs
parents:
diff changeset
  3121
        return KErrArgument;
hgs
parents:
diff changeset
  3122
        }
hgs
parents:
diff changeset
  3123
    else
hgs
parents:
diff changeset
  3124
        {
hgs
parents:
diff changeset
  3125
        const TDesC8& deviceUuid = aDevice.Uuid();
hgs
parents:
diff changeset
  3126
        const TDesC8& statusBuf = appStatusUpdate->Value(); 
hgs
parents:
diff changeset
  3127
hgs
parents:
diff changeset
  3128
        iTmServerTest.iStatusNotified = ETrue;
hgs
parents:
diff changeset
  3129
        }
hgs
parents:
diff changeset
  3130
    return KErrNone;
hgs
parents:
diff changeset
  3131
    }
hgs
parents:
diff changeset
  3132
hgs
parents:
diff changeset
  3133
void CDiscoverDevice::DeviceDiscoveredL( CUpnpDevice* aDevice )
hgs
parents:
diff changeset
  3134
    {
hgs
parents:
diff changeset
  3135
    if( iTmServerTest.iTmServerDeviceType)
hgs
parents:
diff changeset
  3136
        {
hgs
parents:
diff changeset
  3137
        if(aDevice->DeviceType().Compare(KTmServerDevice) == KErrNone )
hgs
parents:
diff changeset
  3138
            {
hgs
parents:
diff changeset
  3139
            iTmServerTest.DeviceVerified();   
hgs
parents:
diff changeset
  3140
            }
hgs
parents:
diff changeset
  3141
        }
hgs
parents:
diff changeset
  3142
    else if( iTmServerTest.iTmServerServiceType)
hgs
parents:
diff changeset
  3143
        {
hgs
parents:
diff changeset
  3144
        if(aDevice->ServiceDescriptionReceiveState()== CUpnpDevice::EAllServicesAdded)
hgs
parents:
diff changeset
  3145
            {
hgs
parents:
diff changeset
  3146
            iTmServerTest.ServiceVerified();
hgs
parents:
diff changeset
  3147
            }
hgs
parents:
diff changeset
  3148
        }
hgs
parents:
diff changeset
  3149
    }
hgs
parents:
diff changeset
  3150
hgs
parents:
diff changeset
  3151
void CDiscoverDevice::DeviceDisappearedL( CUpnpDevice* /*aDevice */)
hgs
parents:
diff changeset
  3152
    {
hgs
parents:
diff changeset
  3153
     iTmServerTest.DeviceLostVerified();
hgs
parents:
diff changeset
  3154
    }
hgs
parents:
diff changeset
  3155
hgs
parents:
diff changeset
  3156
void CDiscoverDevice::ActionResponseReceivedL( CUpnpAction* aAction )
hgs
parents:
diff changeset
  3157
    {
hgs
parents:
diff changeset
  3158
    CUpnpService& service = aAction->Service();
hgs
parents:
diff changeset
  3159
    if( service.ServiceType().Length() <= 0 )
hgs
parents:
diff changeset
  3160
        {
hgs
parents:
diff changeset
  3161
        User::Leave(KErrArgument);
hgs
parents:
diff changeset
  3162
        }
hgs
parents:
diff changeset
  3163
    if (aAction->Name().Compare(KGetApplicationList) == KErrNone)
hgs
parents:
diff changeset
  3164
        {
hgs
parents:
diff changeset
  3165
        aAction->ArgumentValue( KAppListing );
hgs
parents:
diff changeset
  3166
        iTmServerTest.iGetAppList = ETrue;
hgs
parents:
diff changeset
  3167
        }
hgs
parents:
diff changeset
  3168
    else if (aAction->Name().Compare(KLaunchApp) == KErrNone)
hgs
parents:
diff changeset
  3169
        {
hgs
parents:
diff changeset
  3170
        aAction->ArgumentValue( KAppLaunchStatus );
hgs
parents:
diff changeset
  3171
        iTmServerTest.iStartApp = ETrue;
hgs
parents:
diff changeset
  3172
        }
hgs
parents:
diff changeset
  3173
    else if (aAction->Name().Compare(KTerminateApp) == KErrNone)
hgs
parents:
diff changeset
  3174
        {
hgs
parents:
diff changeset
  3175
        aAction->ArgumentValue( KAppTerminateStatus );
hgs
parents:
diff changeset
  3176
        iTmServerTest.iStopApp = ETrue;
hgs
parents:
diff changeset
  3177
        }
hgs
parents:
diff changeset
  3178
    else if (aAction->Name().Compare(KGetAppStatus) == KErrNone)
hgs
parents:
diff changeset
  3179
        {
hgs
parents:
diff changeset
  3180
        aAction->ArgumentValue( KAppStatus );
hgs
parents:
diff changeset
  3181
        iTmServerTest.iGetAppStatus = ETrue;
hgs
parents:
diff changeset
  3182
        }
hgs
parents:
diff changeset
  3183
    else if (aAction->Name().Compare(KSetClientProfile) == KErrNone)
hgs
parents:
diff changeset
  3184
        {
hgs
parents:
diff changeset
  3185
        aAction->ArgumentValue( KResultProfile );
hgs
parents:
diff changeset
  3186
        iTmServerTest.iSetClientProfile = ETrue;
hgs
parents:
diff changeset
  3187
        }
hgs
parents:
diff changeset
  3188
    else if (aAction->Name().Compare(KGetClientProfile) == KErrNone)
hgs
parents:
diff changeset
  3189
        {
hgs
parents:
diff changeset
  3190
        aAction->ArgumentValue( KClientProfile );
hgs
parents:
diff changeset
  3191
        iTmServerTest.iGetClientProfile = ETrue;
hgs
parents:
diff changeset
  3192
        }
hgs
parents:
diff changeset
  3193
    else if (aAction->Name().Compare(KGetMaxNumProfiles) == KErrNone)
hgs
parents:
diff changeset
  3194
        {
hgs
parents:
diff changeset
  3195
        aAction->ArgumentValue( KNumProfilesAllowed );
hgs
parents:
diff changeset
  3196
        iTmServerTest.iGetMaxNumProfiles = ETrue;
hgs
parents:
diff changeset
  3197
        }
hgs
parents:
diff changeset
  3198
    }
hgs
parents:
diff changeset
  3199
hgs
parents:
diff changeset
  3200
 void CDiscoverDevice::HttpResponseReceivedL( CUpnpHttpMessage* /*aMessage*/ )
hgs
parents:
diff changeset
  3201
    {
hgs
parents:
diff changeset
  3202
    
hgs
parents:
diff changeset
  3203
    }
hgs
parents:
diff changeset
  3204
hgs
parents:
diff changeset
  3205
hgs
parents:
diff changeset
  3206
TInt CDiscoverDevice::GetAppListActionL( const TDesC8& aAppListFilter ,TInt aProfileId )
hgs
parents:
diff changeset
  3207
    {
hgs
parents:
diff changeset
  3208
    const RPointerArray<CUpnpDevice>& deviceList = DeviceList();
hgs
parents:
diff changeset
  3209
    if( deviceList.Count() == KErrNone ) 
hgs
parents:
diff changeset
  3210
        {
hgs
parents:
diff changeset
  3211
        return KErrBadHandle;
hgs
parents:
diff changeset
  3212
        }
hgs
parents:
diff changeset
  3213
    TInt i(0);
hgs
parents:
diff changeset
  3214
    while ( deviceList[i]->DeviceType().Compare(KTmServerDevice()) != KErrNone )
hgs
parents:
diff changeset
  3215
        {
hgs
parents:
diff changeset
  3216
        i++;
hgs
parents:
diff changeset
  3217
        }
hgs
parents:
diff changeset
  3218
    if( i == deviceList.Count()) 
hgs
parents:
diff changeset
  3219
        {
hgs
parents:
diff changeset
  3220
        return KErrNotFound;
hgs
parents:
diff changeset
  3221
        }
hgs
parents:
diff changeset
  3222
    RPointerArray<CUpnpService>& services = const_cast<CUpnpDevice*>(deviceList[i])->ServiceList();
hgs
parents:
diff changeset
  3223
    
hgs
parents:
diff changeset
  3224
    for( TInt i(0); i < services.Count(); i++ )
hgs
parents:
diff changeset
  3225
        {
hgs
parents:
diff changeset
  3226
        if( services[i]->ServiceType().Match( KTmServerServiceType ) != KErrNotFound )
hgs
parents:
diff changeset
  3227
            {
hgs
parents:
diff changeset
  3228
            CUpnpAction* action = services[i]->CreateActionLC( KGetApplicationList );
hgs
parents:
diff changeset
  3229
               if( action )
hgs
parents:
diff changeset
  3230
                  {
hgs
parents:
diff changeset
  3231
                  TBuf8<8> buf;
hgs
parents:
diff changeset
  3232
                  buf.Num(aProfileId); 
hgs
parents:
diff changeset
  3233
                  action->SetArgumentL(KAppFilter, aAppListFilter );
hgs
parents:
diff changeset
  3234
                  action->SetArgumentL(KProfileId, buf );
hgs
parents:
diff changeset
  3235
                  SendL( action );                 
hgs
parents:
diff changeset
  3236
                  CleanupStack::Pop( action );
hgs
parents:
diff changeset
  3237
                  return action->SessionId();
hgs
parents:
diff changeset
  3238
                  }
hgs
parents:
diff changeset
  3239
               else
hgs
parents:
diff changeset
  3240
                  {
hgs
parents:
diff changeset
  3241
                  return KErrGeneral;
hgs
parents:
diff changeset
  3242
                  }
hgs
parents:
diff changeset
  3243
            }
hgs
parents:
diff changeset
  3244
        }
hgs
parents:
diff changeset
  3245
    return KErrNotFound;
hgs
parents:
diff changeset
  3246
    }
hgs
parents:
diff changeset
  3247
hgs
parents:
diff changeset
  3248
hgs
parents:
diff changeset
  3249
hgs
parents:
diff changeset
  3250
TInt CDiscoverDevice::LaunchAppActionL( TInt aAppId, TInt aProfileId )
hgs
parents:
diff changeset
  3251
    {
hgs
parents:
diff changeset
  3252
    const RPointerArray<CUpnpDevice>& deviceList = DeviceList();
hgs
parents:
diff changeset
  3253
    if( deviceList.Count() == KErrNone ) 
hgs
parents:
diff changeset
  3254
        {
hgs
parents:
diff changeset
  3255
        return KErrBadHandle;
hgs
parents:
diff changeset
  3256
        }
hgs
parents:
diff changeset
  3257
    TInt i(0);
hgs
parents:
diff changeset
  3258
    while ( deviceList[i]->DeviceType().Compare(KTmServerDevice()) != KErrNone )
hgs
parents:
diff changeset
  3259
        {
hgs
parents:
diff changeset
  3260
        i++;
hgs
parents:
diff changeset
  3261
        }
hgs
parents:
diff changeset
  3262
    if( i == deviceList.Count()) 
hgs
parents:
diff changeset
  3263
        {
hgs
parents:
diff changeset
  3264
        return KErrNotFound;
hgs
parents:
diff changeset
  3265
        }
hgs
parents:
diff changeset
  3266
    RPointerArray<CUpnpService>& services = const_cast<CUpnpDevice*>(deviceList[i])->ServiceList();
hgs
parents:
diff changeset
  3267
    
hgs
parents:
diff changeset
  3268
    for( TInt i(0); i < services.Count(); i++ )
hgs
parents:
diff changeset
  3269
        {
hgs
parents:
diff changeset
  3270
        if( services[i]->ServiceType().Match( KTmServerServiceType ) != KErrNotFound )
hgs
parents:
diff changeset
  3271
            {
hgs
parents:
diff changeset
  3272
            CUpnpAction* action =  services[i]->CreateActionLC( KLaunchApp );
hgs
parents:
diff changeset
  3273
            if( action )
hgs
parents:
diff changeset
  3274
              {
hgs
parents:
diff changeset
  3275
                  TBuf8<8> buf;
hgs
parents:
diff changeset
  3276
                  buf.Num(aAppId);  
hgs
parents:
diff changeset
  3277
                  action->SetArgumentL( KAppId, buf );                                  
hgs
parents:
diff changeset
  3278
                  buf.Zero();
hgs
parents:
diff changeset
  3279
                  buf.Num(aProfileId);  
hgs
parents:
diff changeset
  3280
                  action->SetArgumentL( KProfileId, buf );                  
hgs
parents:
diff changeset
  3281
               }            
hgs
parents:
diff changeset
  3282
              SendL( action );
hgs
parents:
diff changeset
  3283
              CleanupStack::Pop( action );
hgs
parents:
diff changeset
  3284
              return action->SessionId();
hgs
parents:
diff changeset
  3285
              }
hgs
parents:
diff changeset
  3286
            else
hgs
parents:
diff changeset
  3287
              {
hgs
parents:
diff changeset
  3288
              return KErrGeneral;
hgs
parents:
diff changeset
  3289
              }
hgs
parents:
diff changeset
  3290
            }
hgs
parents:
diff changeset
  3291
        return KErrNotFound;
hgs
parents:
diff changeset
  3292
    }
hgs
parents:
diff changeset
  3293
hgs
parents:
diff changeset
  3294
TInt CDiscoverDevice::TerminateAppActionL( TInt aAppId, TInt aProfileId )
hgs
parents:
diff changeset
  3295
    {
hgs
parents:
diff changeset
  3296
    const RPointerArray<CUpnpDevice>& deviceList = DeviceList();
hgs
parents:
diff changeset
  3297
    if( deviceList.Count() == KErrNone ) 
hgs
parents:
diff changeset
  3298
        {
hgs
parents:
diff changeset
  3299
        return KErrBadHandle;
hgs
parents:
diff changeset
  3300
        }
hgs
parents:
diff changeset
  3301
    TInt i(0);
hgs
parents:
diff changeset
  3302
    while ( deviceList[i]->DeviceType().Compare(KTmServerDevice()) != KErrNone )
hgs
parents:
diff changeset
  3303
        {
hgs
parents:
diff changeset
  3304
        i++;
hgs
parents:
diff changeset
  3305
        }
hgs
parents:
diff changeset
  3306
    if( i == deviceList.Count()) 
hgs
parents:
diff changeset
  3307
        {
hgs
parents:
diff changeset
  3308
        return KErrNotFound;
hgs
parents:
diff changeset
  3309
        }
hgs
parents:
diff changeset
  3310
    RPointerArray<CUpnpService>& services = const_cast<CUpnpDevice*>(deviceList[i])->ServiceList();
hgs
parents:
diff changeset
  3311
    
hgs
parents:
diff changeset
  3312
    for( TInt i(0); i < services.Count(); i++ )
hgs
parents:
diff changeset
  3313
        {
hgs
parents:
diff changeset
  3314
        if( services[i]->ServiceType().Match( KTmServerServiceType ) != KErrNotFound )
hgs
parents:
diff changeset
  3315
            {
hgs
parents:
diff changeset
  3316
            CUpnpAction* action =  services[i]->CreateActionLC( KTerminateApp );
hgs
parents:
diff changeset
  3317
            if( action )
hgs
parents:
diff changeset
  3318
              {
hgs
parents:
diff changeset
  3319
                  TBuf8<8> buf;
hgs
parents:
diff changeset
  3320
                  buf.Num(aAppId);             
hgs
parents:
diff changeset
  3321
                  action->SetArgumentL( KAppId, buf );
hgs
parents:
diff changeset
  3322
                  buf.Zero();
hgs
parents:
diff changeset
  3323
                  buf.Num(aProfileId);             
hgs
parents:
diff changeset
  3324
                  action->SetArgumentL( KProfileId, buf );
hgs
parents:
diff changeset
  3325
               }            
hgs
parents:
diff changeset
  3326
hgs
parents:
diff changeset
  3327
              SendL( action );
hgs
parents:
diff changeset
  3328
              CleanupStack::Pop( action );
hgs
parents:
diff changeset
  3329
              return action->SessionId();
hgs
parents:
diff changeset
  3330
              }
hgs
parents:
diff changeset
  3331
            else
hgs
parents:
diff changeset
  3332
              {
hgs
parents:
diff changeset
  3333
              return KErrGeneral;
hgs
parents:
diff changeset
  3334
              }
hgs
parents:
diff changeset
  3335
            }       
hgs
parents:
diff changeset
  3336
    return KErrNotFound;
hgs
parents:
diff changeset
  3337
    }
hgs
parents:
diff changeset
  3338
hgs
parents:
diff changeset
  3339
TInt CDiscoverDevice::GetAppStatusActionL( TInt aAppId )
hgs
parents:
diff changeset
  3340
    {
hgs
parents:
diff changeset
  3341
    const RPointerArray<CUpnpDevice>& deviceList = DeviceList();
hgs
parents:
diff changeset
  3342
    if( deviceList.Count() == KErrNone ) 
hgs
parents:
diff changeset
  3343
        {
hgs
parents:
diff changeset
  3344
        return KErrBadHandle;
hgs
parents:
diff changeset
  3345
        }
hgs
parents:
diff changeset
  3346
    TInt i(0);
hgs
parents:
diff changeset
  3347
    while ( deviceList[i]->DeviceType().Compare(KTmServerDevice()) != KErrNone )
hgs
parents:
diff changeset
  3348
        {
hgs
parents:
diff changeset
  3349
        i++;
hgs
parents:
diff changeset
  3350
        }
hgs
parents:
diff changeset
  3351
    if( i == deviceList.Count()) 
hgs
parents:
diff changeset
  3352
        {
hgs
parents:
diff changeset
  3353
        return KErrNotFound;
hgs
parents:
diff changeset
  3354
        }
hgs
parents:
diff changeset
  3355
    RPointerArray<CUpnpService>& services = const_cast<CUpnpDevice*>(deviceList[i])->ServiceList();
hgs
parents:
diff changeset
  3356
    
hgs
parents:
diff changeset
  3357
    for( TInt i(0); i < services.Count(); i++ )
hgs
parents:
diff changeset
  3358
        {
hgs
parents:
diff changeset
  3359
        if( services[i]->ServiceType().Match( KTmServerServiceType ) != KErrNotFound )
hgs
parents:
diff changeset
  3360
            {
hgs
parents:
diff changeset
  3361
            CUpnpAction* action = services[i]->CreateActionLC( KGetAppStatus );
hgs
parents:
diff changeset
  3362
            if( action )
hgs
parents:
diff changeset
  3363
               {
hgs
parents:
diff changeset
  3364
               TBuf8<8> buf;
hgs
parents:
diff changeset
  3365
               buf.Num(aAppId); 
hgs
parents:
diff changeset
  3366
               if ( aAppId == KAppId1Value || aAppId == KNonExistentAppIdValue )
hgs
parents:
diff changeset
  3367
                    {   
hgs
parents:
diff changeset
  3368
                    action->SetArgumentL( KAppId, buf );                 
hgs
parents:
diff changeset
  3369
                    }              
hgs
parents:
diff changeset
  3370
               else if( aAppId == KAppId5Value )
hgs
parents:
diff changeset
  3371
                   {
hgs
parents:
diff changeset
  3372
                    _LIT8(KWildCard, "*");
hgs
parents:
diff changeset
  3373
                    action->SetArgumentL( KAppId, KWildCard());
hgs
parents:
diff changeset
  3374
                   }   
hgs
parents:
diff changeset
  3375
               else
hgs
parents:
diff changeset
  3376
                   {
hgs
parents:
diff changeset
  3377
                   action->SetArgumentL( KAppId, KNullDesC8());
hgs
parents:
diff changeset
  3378
                   }
hgs
parents:
diff changeset
  3379
               SendL( action );
hgs
parents:
diff changeset
  3380
               CleanupStack::Pop( action );
hgs
parents:
diff changeset
  3381
               return action->SessionId();
hgs
parents:
diff changeset
  3382
               }
hgs
parents:
diff changeset
  3383
            else
hgs
parents:
diff changeset
  3384
               {
hgs
parents:
diff changeset
  3385
               return KErrGeneral;
hgs
parents:
diff changeset
  3386
               }
hgs
parents:
diff changeset
  3387
             }
hgs
parents:
diff changeset
  3388
         }
hgs
parents:
diff changeset
  3389
     return KErrNotFound;
hgs
parents:
diff changeset
  3390
     }
hgs
parents:
diff changeset
  3391
hgs
parents:
diff changeset
  3392
TInt CDiscoverDevice::SetClientProfileActionL(TInt aProfileId, const TDesC8& aClientInfoValue )
hgs
parents:
diff changeset
  3393
    {
hgs
parents:
diff changeset
  3394
    const RPointerArray<CUpnpDevice>& deviceList = DeviceList();
hgs
parents:
diff changeset
  3395
    if( deviceList.Count() == KErrNone ) 
hgs
parents:
diff changeset
  3396
        {
hgs
parents:
diff changeset
  3397
        return KErrBadHandle;
hgs
parents:
diff changeset
  3398
        }
hgs
parents:
diff changeset
  3399
    TInt i(0);
hgs
parents:
diff changeset
  3400
    while ( deviceList[i]->DeviceType().Compare(KTmServerDevice()) != KErrNone )
hgs
parents:
diff changeset
  3401
        {
hgs
parents:
diff changeset
  3402
        i++;
hgs
parents:
diff changeset
  3403
        }
hgs
parents:
diff changeset
  3404
    if( i == deviceList.Count()) 
hgs
parents:
diff changeset
  3405
        {
hgs
parents:
diff changeset
  3406
        return KErrNotFound;
hgs
parents:
diff changeset
  3407
        }
hgs
parents:
diff changeset
  3408
    RPointerArray<CUpnpService>& services = const_cast<CUpnpDevice*>(deviceList[i])->ServiceList();
hgs
parents:
diff changeset
  3409
    
hgs
parents:
diff changeset
  3410
    for( TInt i(0); i < services.Count(); i++ )
hgs
parents:
diff changeset
  3411
        {
hgs
parents:
diff changeset
  3412
        if( services[i]->ServiceType().Match( KTmServerServiceType1 ) != KErrNotFound )
hgs
parents:
diff changeset
  3413
            {
hgs
parents:
diff changeset
  3414
            CUpnpAction* action = services[i]->CreateActionLC( KSetClientProfile);
hgs
parents:
diff changeset
  3415
            if( action )
hgs
parents:
diff changeset
  3416
               {   
hgs
parents:
diff changeset
  3417
               TBuf8<8> buf;
hgs
parents:
diff changeset
  3418
               buf.Num(aProfileId); 
hgs
parents:
diff changeset
  3419
               action->SetArgumentL(KProfileId1, buf );
hgs
parents:
diff changeset
  3420
               action->SetArgumentL(KClientProfile, aClientInfoValue );
hgs
parents:
diff changeset
  3421
               SendL( action );
hgs
parents:
diff changeset
  3422
               CleanupStack::Pop( action );
hgs
parents:
diff changeset
  3423
               return action->SessionId();
hgs
parents:
diff changeset
  3424
               }
hgs
parents:
diff changeset
  3425
            else
hgs
parents:
diff changeset
  3426
               {
hgs
parents:
diff changeset
  3427
               return KErrGeneral;
hgs
parents:
diff changeset
  3428
               }
hgs
parents:
diff changeset
  3429
             }
hgs
parents:
diff changeset
  3430
         }
hgs
parents:
diff changeset
  3431
     return KErrNotFound;
hgs
parents:
diff changeset
  3432
     }
hgs
parents:
diff changeset
  3433
hgs
parents:
diff changeset
  3434
TInt CDiscoverDevice::GetClientProfileActionL(TInt aProfileId )
hgs
parents:
diff changeset
  3435
    {
hgs
parents:
diff changeset
  3436
    const RPointerArray<CUpnpDevice>& deviceList = DeviceList();
hgs
parents:
diff changeset
  3437
    if( deviceList.Count() == KErrNone ) 
hgs
parents:
diff changeset
  3438
        {
hgs
parents:
diff changeset
  3439
        return KErrBadHandle;
hgs
parents:
diff changeset
  3440
        }
hgs
parents:
diff changeset
  3441
    TInt i(0);
hgs
parents:
diff changeset
  3442
    while ( deviceList[i]->DeviceType().Compare(KTmServerDevice()) != KErrNone )
hgs
parents:
diff changeset
  3443
        {
hgs
parents:
diff changeset
  3444
        i++;
hgs
parents:
diff changeset
  3445
        }
hgs
parents:
diff changeset
  3446
    if( i == deviceList.Count()) 
hgs
parents:
diff changeset
  3447
        {
hgs
parents:
diff changeset
  3448
        return KErrNotFound;
hgs
parents:
diff changeset
  3449
        }
hgs
parents:
diff changeset
  3450
    RPointerArray<CUpnpService>& services = const_cast<CUpnpDevice*>(deviceList[i])->ServiceList();
hgs
parents:
diff changeset
  3451
    
hgs
parents:
diff changeset
  3452
    for( TInt i(0); i < services.Count(); i++ )
hgs
parents:
diff changeset
  3453
        {
hgs
parents:
diff changeset
  3454
        if( services[i]->ServiceType().Match( KTmServerServiceType1 ) != KErrNotFound )
hgs
parents:
diff changeset
  3455
            {
hgs
parents:
diff changeset
  3456
            CUpnpAction* action = services[i]->CreateActionLC( KGetClientProfile);
hgs
parents:
diff changeset
  3457
            if( action )
hgs
parents:
diff changeset
  3458
               {   
hgs
parents:
diff changeset
  3459
               TBuf8<8> buf;
hgs
parents:
diff changeset
  3460
               buf.Num(aProfileId); 
hgs
parents:
diff changeset
  3461
               action->SetArgumentL(KProfileId1, buf );
hgs
parents:
diff changeset
  3462
               SendL( action );
hgs
parents:
diff changeset
  3463
               CleanupStack::Pop( action );
hgs
parents:
diff changeset
  3464
               return action->SessionId();
hgs
parents:
diff changeset
  3465
               }
hgs
parents:
diff changeset
  3466
            else
hgs
parents:
diff changeset
  3467
               {
hgs
parents:
diff changeset
  3468
               return KErrGeneral;
hgs
parents:
diff changeset
  3469
               }
hgs
parents:
diff changeset
  3470
             }
hgs
parents:
diff changeset
  3471
         }
hgs
parents:
diff changeset
  3472
     return KErrNotFound;
hgs
parents:
diff changeset
  3473
     }
hgs
parents:
diff changeset
  3474
hgs
parents:
diff changeset
  3475
TInt CDiscoverDevice::GetMaxNumProfilesActionL( )
hgs
parents:
diff changeset
  3476
    {
hgs
parents:
diff changeset
  3477
    const RPointerArray<CUpnpDevice>& deviceList = DeviceList();
hgs
parents:
diff changeset
  3478
    if( deviceList.Count() == KErrNone ) 
hgs
parents:
diff changeset
  3479
        {
hgs
parents:
diff changeset
  3480
        return KErrBadHandle;
hgs
parents:
diff changeset
  3481
        }
hgs
parents:
diff changeset
  3482
    TInt i(0);
hgs
parents:
diff changeset
  3483
    while ( deviceList[i]->DeviceType().Compare(KTmServerDevice()) != KErrNone )
hgs
parents:
diff changeset
  3484
        {
hgs
parents:
diff changeset
  3485
        i++;
hgs
parents:
diff changeset
  3486
        }
hgs
parents:
diff changeset
  3487
    if( i == deviceList.Count()) 
hgs
parents:
diff changeset
  3488
        {
hgs
parents:
diff changeset
  3489
        return KErrNotFound;
hgs
parents:
diff changeset
  3490
        }
hgs
parents:
diff changeset
  3491
    RPointerArray<CUpnpService>& services = const_cast<CUpnpDevice*>(deviceList[i])->ServiceList();
hgs
parents:
diff changeset
  3492
    
hgs
parents:
diff changeset
  3493
    for( TInt i(0); i < services.Count(); i++ )
hgs
parents:
diff changeset
  3494
        {
hgs
parents:
diff changeset
  3495
        if( services[i]->ServiceType().Match( KTmServerServiceType1 ) != KErrNotFound )
hgs
parents:
diff changeset
  3496
            {
hgs
parents:
diff changeset
  3497
            CUpnpAction* action = services[i]->CreateActionLC( KGetMaxNumProfiles);
hgs
parents:
diff changeset
  3498
            if( action )
hgs
parents:
diff changeset
  3499
               {   
hgs
parents:
diff changeset
  3500
               SendL( action );
hgs
parents:
diff changeset
  3501
               CleanupStack::Pop( action );
hgs
parents:
diff changeset
  3502
               return action->SessionId();
hgs
parents:
diff changeset
  3503
               }
hgs
parents:
diff changeset
  3504
            else
hgs
parents:
diff changeset
  3505
               {
hgs
parents:
diff changeset
  3506
               return KErrGeneral;
hgs
parents:
diff changeset
  3507
               }
hgs
parents:
diff changeset
  3508
             }
hgs
parents:
diff changeset
  3509
         }
hgs
parents:
diff changeset
  3510
     return KErrNotFound;
hgs
parents:
diff changeset
  3511
     }
hgs
parents:
diff changeset
  3512
hgs
parents:
diff changeset
  3513
void CDiscoverDevice::SubscribeToServiceL()
hgs
parents:
diff changeset
  3514
    {
hgs
parents:
diff changeset
  3515
    const RPointerArray<CUpnpDevice>& deviceList = DeviceList();
hgs
parents:
diff changeset
  3516
    if( deviceList.Count() == KErrNone ) 
hgs
parents:
diff changeset
  3517
        {
hgs
parents:
diff changeset
  3518
        User::Leave( KErrBadHandle );
hgs
parents:
diff changeset
  3519
        }
hgs
parents:
diff changeset
  3520
    TInt i(0);
hgs
parents:
diff changeset
  3521
    while ( deviceList[i]->DeviceType().Compare(KTmServerDevice()) != KErrNone )
hgs
parents:
diff changeset
  3522
        {
hgs
parents:
diff changeset
  3523
        i++;
hgs
parents:
diff changeset
  3524
        }
hgs
parents:
diff changeset
  3525
    if( i == deviceList.Count()) 
hgs
parents:
diff changeset
  3526
        {
hgs
parents:
diff changeset
  3527
        User::Leave ( KErrNotFound );
hgs
parents:
diff changeset
  3528
        }
hgs
parents:
diff changeset
  3529
        RPointerArray<CUpnpService>& services = const_cast<CUpnpDevice*>(deviceList[i])->ServiceList();
hgs
parents:
diff changeset
  3530
        
hgs
parents:
diff changeset
  3531
    for( TInt i(0); i < services.Count(); i++ )
hgs
parents:
diff changeset
  3532
        {
hgs
parents:
diff changeset
  3533
        if( services[i]->ServiceType().Match( KTmServerServiceType ) != KErrNotFound )
hgs
parents:
diff changeset
  3534
            {
hgs
parents:
diff changeset
  3535
            SubscribeL( services[i] ); 
hgs
parents:
diff changeset
  3536
            }
hgs
parents:
diff changeset
  3537
        }
hgs
parents:
diff changeset
  3538
    }
hgs
parents:
diff changeset
  3539
hgs
parents:
diff changeset
  3540
TTerminalModeErrorCode CTmServerTest::OnGetApplicationList(TUint aProfileId ) 
hgs
parents:
diff changeset
  3541
    {
hgs
parents:
diff changeset
  3542
    if(iOperationRejected )
hgs
parents:
diff changeset
  3543
        {
hgs
parents:
diff changeset
  3544
        return ETerminalModeOperationRejected;
hgs
parents:
diff changeset
  3545
        }
hgs
parents:
diff changeset
  3546
    else if ( ( aProfileId == 0 ) || ( aProfileId == 1 ) || ( aProfileId == 2) || ( aProfileId == 3 ) 
hgs
parents:
diff changeset
  3547
            || ( aProfileId == 4 ) || ( aProfileId == 5 ) || ( aProfileId == 6 ) ) 
hgs
parents:
diff changeset
  3548
        { 
hgs
parents:
diff changeset
  3549
        return ETerminalModeSuccess;   
hgs
parents:
diff changeset
  3550
        } 
hgs
parents:
diff changeset
  3551
    return ETerminalModeInvalidProfileId; 
hgs
parents:
diff changeset
  3552
    }
hgs
parents:
diff changeset
  3553
hgs
parents:
diff changeset
  3554
TTerminalModeErrorCode CTmServerTest::OnLaunchApp( TUint aAppId, RBuf8& aUrl, TUint aProfileId )                                                                       
hgs
parents:
diff changeset
  3555
    {
hgs
parents:
diff changeset
  3556
    if ( ( aProfileId != 0 ) && ( aProfileId != 1 ) && ( aProfileId != 2) && ( aProfileId != 3 ) 
hgs
parents:
diff changeset
  3557
             && ( aProfileId != 4 ) && ( aProfileId != 5 ) && ( aProfileId != 6 ) ) 
hgs
parents:
diff changeset
  3558
        { 
hgs
parents:
diff changeset
  3559
        return ETerminalModeInvalidProfileId;   
hgs
parents:
diff changeset
  3560
        }
hgs
parents:
diff changeset
  3561
    aUrl.Close();
hgs
parents:
diff changeset
  3562
    if ( aAppId == KAppIdValue )
hgs
parents:
diff changeset
  3563
        {
hgs
parents:
diff changeset
  3564
        _LIT8(KUrl, "VNC://192.168.4.1:5900");
hgs
parents:
diff changeset
  3565
        aUrl.Create(KUrl());
hgs
parents:
diff changeset
  3566
        }
hgs
parents:
diff changeset
  3567
    else if ( aAppId == KAppId1Value )
hgs
parents:
diff changeset
  3568
        {
hgs
parents:
diff changeset
  3569
        _LIT8(KUrl, "RTP://192.168.2.1:5900");
hgs
parents:
diff changeset
  3570
        aUrl.Create(KUrl());
hgs
parents:
diff changeset
  3571
        }
hgs
parents:
diff changeset
  3572
    else if ( aAppId == KAppId2Value )
hgs
parents:
diff changeset
  3573
        {
hgs
parents:
diff changeset
  3574
        _LIT8(KUrl, "BTA2DP://192.168.2.1:5900");
hgs
parents:
diff changeset
  3575
        aUrl.Create(KUrl());
hgs
parents:
diff changeset
  3576
        }
hgs
parents:
diff changeset
  3577
    else if  ( aAppId == KAppId3Value)
hgs
parents:
diff changeset
  3578
        {
hgs
parents:
diff changeset
  3579
        _LIT8(KUrl, "BTHFP://192.168.2.1:5900");
hgs
parents:
diff changeset
  3580
        aUrl.Create(KUrl());
hgs
parents:
diff changeset
  3581
        }
hgs
parents:
diff changeset
  3582
    else if  ( aAppId == KAppId4Value)
hgs
parents:
diff changeset
  3583
        {
hgs
parents:
diff changeset
  3584
        return ETerminalModeDeviceLocked;
hgs
parents:
diff changeset
  3585
        }
hgs
parents:
diff changeset
  3586
    else 
hgs
parents:
diff changeset
  3587
        {
hgs
parents:
diff changeset
  3588
        return ETerminalModeUnauthorizedApp;
hgs
parents:
diff changeset
  3589
        }   
hgs
parents:
diff changeset
  3590
    return ETerminalModeSuccess;
hgs
parents:
diff changeset
  3591
    }
hgs
parents:
diff changeset
  3592
    
hgs
parents:
diff changeset
  3593
TTerminalModeErrorCode CTmServerTest::OnTerminateApp( TUint aAppId, TUint aProfileId )
hgs
parents:
diff changeset
  3594
    {
hgs
parents:
diff changeset
  3595
    if ( ( aProfileId != 0 ) && ( aProfileId != 1 ) && ( aProfileId != 2) && ( aProfileId != 3 ) 
hgs
parents:
diff changeset
  3596
             && ( aProfileId != 4 ) && ( aProfileId != 5 ) && ( aProfileId != 6 ) ) 
hgs
parents:
diff changeset
  3597
         { 
hgs
parents:
diff changeset
  3598
         return ETerminalModeInvalidProfileId;   
hgs
parents:
diff changeset
  3599
         }
hgs
parents:
diff changeset
  3600
   if ( aAppId == KAppIdValue|| aAppId == KAppId1Value || aAppId == KAppId2Value || aAppId == KAppId3Value)
hgs
parents:
diff changeset
  3601
       {
hgs
parents:
diff changeset
  3602
        return ETerminalModeSuccess;
hgs
parents:
diff changeset
  3603
       }
hgs
parents:
diff changeset
  3604
   else if  ( aAppId == KAppId4Value)
hgs
parents:
diff changeset
  3605
       {
hgs
parents:
diff changeset
  3606
        return ETerminalModeDeviceLocked;
hgs
parents:
diff changeset
  3607
       }
hgs
parents:
diff changeset
  3608
   else
hgs
parents:
diff changeset
  3609
       {
hgs
parents:
diff changeset
  3610
        return ETerminalModeUnauthorizedApp;
hgs
parents:
diff changeset
  3611
       }
hgs
parents:
diff changeset
  3612
    }
hgs
parents:
diff changeset
  3613
hgs
parents:
diff changeset
  3614
TTerminalModeErrorCode CTmServerTest::OnGetAppStatus(  TUint aAppId, TUint& aProfileId ,RBuf8& aStatusType )
hgs
parents:
diff changeset
  3615
    {
hgs
parents:
diff changeset
  3616
    aProfileId = KErrNone;
hgs
parents:
diff changeset
  3617
    aStatusType.Close();
hgs
parents:
diff changeset
  3618
    if ( aAppId == KAppIdValue )
hgs
parents:
diff changeset
  3619
        {
hgs
parents:
diff changeset
  3620
        aStatusType.Create(KBackground());
hgs
parents:
diff changeset
  3621
        }
hgs
parents:
diff changeset
  3622
    else if ( aAppId == KAppId1Value )
hgs
parents:
diff changeset
  3623
        {
hgs
parents:
diff changeset
  3624
         aStatusType.Create(KForeground());
hgs
parents:
diff changeset
  3625
        }
hgs
parents:
diff changeset
  3626
    else if ( aAppId == KAppId2Value )
hgs
parents:
diff changeset
  3627
        {
hgs
parents:
diff changeset
  3628
        aStatusType.Create(KBackground());
hgs
parents:
diff changeset
  3629
        }
hgs
parents:
diff changeset
  3630
    else if ( aAppId == KAppId3Value )
hgs
parents:
diff changeset
  3631
        {
hgs
parents:
diff changeset
  3632
        aStatusType.Create(KForeground());
hgs
parents:
diff changeset
  3633
        }  
hgs
parents:
diff changeset
  3634
    else
hgs
parents:
diff changeset
  3635
        {
hgs
parents:
diff changeset
  3636
        aStatusType.Create(KBackground());
hgs
parents:
diff changeset
  3637
        } 
hgs
parents:
diff changeset
  3638
    return ETerminalModeSuccess;
hgs
parents:
diff changeset
  3639
    }
hgs
parents:
diff changeset
  3640
hgs
parents:
diff changeset
  3641
TTerminalModeErrorCode CTmServerTest::OnGetMaxNumProfiles( TUint& aProfileIdCount )
hgs
parents:
diff changeset
  3642
    {
hgs
parents:
diff changeset
  3643
    if (iOperationRejected )
hgs
parents:
diff changeset
  3644
        {
hgs
parents:
diff changeset
  3645
        return ETerminalModeOperationRejected;
hgs
parents:
diff changeset
  3646
        }
hgs
parents:
diff changeset
  3647
    else
hgs
parents:
diff changeset
  3648
        {
hgs
parents:
diff changeset
  3649
        aProfileIdCount = 9;
hgs
parents:
diff changeset
  3650
        return ETerminalModeSuccess;  
hgs
parents:
diff changeset
  3651
        }
hgs
parents:
diff changeset
  3652
    }
hgs
parents:
diff changeset
  3653
hgs
parents:
diff changeset
  3654
TTerminalModeErrorCode CTmServerTest::OnSetClientProfile(TUint aProfileId, const TDesC8& aClientProfile,RBuf8& aResultProfile  )
hgs
parents:
diff changeset
  3655
    {
hgs
parents:
diff changeset
  3656
    _LIT8(KClientInfo,"<clientProfile><clientID>Cl_2</clientID></clientProfile>");
hgs
parents:
diff changeset
  3657
    if(iResourceBusy)
hgs
parents:
diff changeset
  3658
        {
hgs
parents:
diff changeset
  3659
        return ETerminalModeResourceBusy;
hgs
parents:
diff changeset
  3660
        }
hgs
parents:
diff changeset
  3661
    else if(aClientProfile.Compare(KClientInfo()) == KErrNone )
hgs
parents:
diff changeset
  3662
         {
hgs
parents:
diff changeset
  3663
         return ETerminalModeDeviceLocked;   
hgs
parents:
diff changeset
  3664
         }  
hgs
parents:
diff changeset
  3665
    else if ( ( aClientProfile.Find(_L8("<clientProfile><")) == KErrNotFound ) &&
hgs
parents:
diff changeset
  3666
        ( aClientProfile.Find(_L8("&lt;clientProfile&gt;&lt;")) == KErrNotFound ))
hgs
parents:
diff changeset
  3667
       {
hgs
parents:
diff changeset
  3668
       return ETerminalModeInvalidProfile;   
hgs
parents:
diff changeset
  3669
       }
hgs
parents:
diff changeset
  3670
    CUpnpTmClientIconPref* clientIconPref = NULL;
hgs
parents:
diff changeset
  3671
    if ( aProfileId == 0 )
hgs
parents:
diff changeset
  3672
       {
hgs
parents:
diff changeset
  3673
       // different mime type but same dimension
hgs
parents:
diff changeset
  3674
       clientIconPref = CUpnpTmClientIconPref::NewL(0);
hgs
parents:
diff changeset
  3675
       clientIconPref->SetWidth(88);
hgs
parents:
diff changeset
  3676
       clientIconPref->SetHeight(88);   
hgs
parents:
diff changeset
  3677
       }
hgs
parents:
diff changeset
  3678
    else if ( aProfileId == 1 )
hgs
parents:
diff changeset
  3679
       {
hgs
parents:
diff changeset
  3680
       // different mime type and different dimension
hgs
parents:
diff changeset
  3681
       clientIconPref = CUpnpTmClientIconPref::NewL(1);
hgs
parents:
diff changeset
  3682
       clientIconPref->SetMimeTypeL(_L8("image/bmp"));
hgs
parents:
diff changeset
  3683
       clientIconPref->SetWidth(60);
hgs
parents:
diff changeset
  3684
       clientIconPref->SetHeight(60);   
hgs
parents:
diff changeset
  3685
       }
hgs
parents:
diff changeset
  3686
    else if ( aProfileId == 2 )
hgs
parents:
diff changeset
  3687
       {
hgs
parents:
diff changeset
  3688
       // different mime type and no dimension specified by the client
hgs
parents:
diff changeset
  3689
       clientIconPref = CUpnpTmClientIconPref::NewL(2); 
hgs
parents:
diff changeset
  3690
       clientIconPref->SetMimeTypeL(_L8("image/bmp"));
hgs
parents:
diff changeset
  3691
       }
hgs
parents:
diff changeset
  3692
    else if ( aProfileId == 3 )
hgs
parents:
diff changeset
  3693
       {
hgs
parents:
diff changeset
  3694
       // same mime type but different dimension
hgs
parents:
diff changeset
  3695
       clientIconPref = CUpnpTmClientIconPref::NewL(3);
hgs
parents:
diff changeset
  3696
       clientIconPref->SetMimeTypeL(_L8("image/svg+xml"));
hgs
parents:
diff changeset
  3697
       clientIconPref->SetWidth(36);
hgs
parents:
diff changeset
  3698
       clientIconPref->SetHeight(44);       
hgs
parents:
diff changeset
  3699
       }
hgs
parents:
diff changeset
  3700
    else if ( aProfileId == 4 )
hgs
parents:
diff changeset
  3701
       {
hgs
parents:
diff changeset
  3702
       // same mime type but no dimension specified by the client
hgs
parents:
diff changeset
  3703
       clientIconPref = CUpnpTmClientIconPref::NewL(4);
hgs
parents:
diff changeset
  3704
       clientIconPref->SetMimeTypeL(_L8("image/svg+xml"));  
hgs
parents:
diff changeset
  3705
       }
hgs
parents:
diff changeset
  3706
    else if ( aProfileId == 5 )
hgs
parents:
diff changeset
  3707
       {
hgs
parents:
diff changeset
  3708
       // same mime type and same dimension
hgs
parents:
diff changeset
  3709
       clientIconPref = CUpnpTmClientIconPref::NewL(5);
hgs
parents:
diff changeset
  3710
       clientIconPref->SetMimeTypeL(_L8("image/svg+xml")); 
hgs
parents:
diff changeset
  3711
       clientIconPref->SetWidth(88);
hgs
parents:
diff changeset
  3712
       clientIconPref->SetHeight(88); 
hgs
parents:
diff changeset
  3713
       }
hgs
parents:
diff changeset
  3714
    else if ( aProfileId == 6 )
hgs
parents:
diff changeset
  3715
        {
hgs
parents:
diff changeset
  3716
        // different mime type(jpeg) and different dimensions
hgs
parents:
diff changeset
  3717
        clientIconPref = CUpnpTmClientIconPref::NewL(6);
hgs
parents:
diff changeset
  3718
        clientIconPref->SetMimeTypeL(_L8("image/jpeg")); 
hgs
parents:
diff changeset
  3719
        clientIconPref->SetWidth(36);
hgs
parents:
diff changeset
  3720
        clientIconPref->SetHeight(44); 
hgs
parents:
diff changeset
  3721
        }
hgs
parents:
diff changeset
  3722
    else
hgs
parents:
diff changeset
  3723
       {
hgs
parents:
diff changeset
  3724
       return ETerminalModeInvalidProfileId;     
hgs
parents:
diff changeset
  3725
       }
hgs
parents:
diff changeset
  3726
    iClientIconPrefArray.AppendL(clientIconPref);
hgs
parents:
diff changeset
  3727
    RBuf8 clientProfile;
hgs
parents:
diff changeset
  3728
    clientProfile.Create(aClientProfile);
hgs
parents:
diff changeset
  3729
    aResultProfile.Close();
hgs
parents:
diff changeset
  3730
    aResultProfile.Create(clientProfile);
hgs
parents:
diff changeset
  3731
    clientProfile.Close();
hgs
parents:
diff changeset
  3732
    return ETerminalModeSuccess;
hgs
parents:
diff changeset
  3733
    }
hgs
parents:
diff changeset
  3734
hgs
parents:
diff changeset
  3735
TTerminalModeErrorCode CTmServerTest::OnGetClientProfile( TUint aProfileId, RBuf8& aClientProfile)
hgs
parents:
diff changeset
  3736
    {
hgs
parents:
diff changeset
  3737
    if ( ( aProfileId == 0 ) || ( aProfileId == 1 ) || ( aProfileId == 2) || ( aProfileId == 3 ) 
hgs
parents:
diff changeset
  3738
            || ( aProfileId == 4 ) || ( aProfileId == 5 ) || ( aProfileId == 6 ) ) 
hgs
parents:
diff changeset
  3739
         { 
hgs
parents:
diff changeset
  3740
         aClientProfile.Close();
hgs
parents:
diff changeset
  3741
         aClientProfile.Create(KClientProfile());
hgs
parents:
diff changeset
  3742
         return ETerminalModeSuccess;   
hgs
parents:
diff changeset
  3743
         } 
hgs
parents:
diff changeset
  3744
    return ETerminalModeInvalidProfileId;  
hgs
parents:
diff changeset
  3745
    }
hgs
parents:
diff changeset
  3746
hgs
parents:
diff changeset
  3747
const CUpnpTmClientIconPref& CTmServerTest::GetClientIconPrefsL( TUint aProfileId )
hgs
parents:
diff changeset
  3748
    {
hgs
parents:
diff changeset
  3749
    CUpnpTmClientIconPref* clientIconPref = NULL;
hgs
parents:
diff changeset
  3750
    for ( TInt i(0); i < iClientIconPrefArray.Count(); i++ )
hgs
parents:
diff changeset
  3751
        {
hgs
parents:
diff changeset
  3752
        if ( iClientIconPrefArray[i]->ClientProfileId() == aProfileId )     
hgs
parents:
diff changeset
  3753
            {
hgs
parents:
diff changeset
  3754
            clientIconPref = iClientIconPrefArray[i];  
hgs
parents:
diff changeset
  3755
            break;
hgs
parents:
diff changeset
  3756
            }
hgs
parents:
diff changeset
  3757
        }
hgs
parents:
diff changeset
  3758
    return *clientIconPref;
hgs
parents:
diff changeset
  3759
    }
hgs
parents:
diff changeset
  3760