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