wapstack/wapmessageapi/te_wapstack/src/WapBoundCLPushSteps.cpp
author hgs
Mon, 09 Aug 2010 17:43:08 +0100
changeset 59 ac20d6a0a19d
parent 44 8b72faa1200f
permissions -rw-r--r--
201029_06
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
44
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     1
// Copyright (c) 2002-2010 Nokia Corporation and/or its subsidiary(-ies).
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     2
// All rights reserved.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     7
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     8
// Initial Contributors:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    10
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    11
// Contributors:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    12
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    13
// Description:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    14
// CBoundCLPushStep_xyz derived implementations
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    15
// 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    16
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    17
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    18
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    19
 @file
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    20
 @internalComponent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    21
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    22
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    23
#include "WapBoundCLPushSteps.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    24
#include "WapStackSuiteDefs.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    25
#include <simtsy.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    26
#include <wapmsgerr.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    27
#include <ecom/ecom.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    28
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    29
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    30
CBoundCLPushStepBase::CBoundCLPushStepBase()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    31
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    32
* Constructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    33
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    34
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    35
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    36
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    37
CBoundCLPushStepBase::~CBoundCLPushStepBase()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    38
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    39
* Destructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    40
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    41
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    42
	if(iImp) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    43
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    44
		UnloadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    45
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    46
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    47
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    48
// Load CWapBoundCLPushService Interface 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    49
CWapBoundCLPushService* CBoundCLPushStepBase::LoadInterface()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    50
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    51
	TInt trapValue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    52
	CWapBoundCLPushService* implementation = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    53
	// UID {0x101FBB39} - SWS implementation
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    54
	TUid KInterfaceUid = {0x101FBB39}; 	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    55
	INFO_PRINTF2(_L("Calling new NewL(0x%08X) method"), KInterfaceUid);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    56
	TRAP(trapValue, implementation = CWapBoundCLPushService::NewL(KInterfaceUid));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    57
	if(!trapValue)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    58
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    59
		INFO_PRINTF2(_L("Interface is loaded: implementation.addr = 0x%08x"), implementation);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    60
		return implementation;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    61
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    62
	else return NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    63
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    64
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    65
void CBoundCLPushStepBase::UnloadInterface()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    66
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    67
	INFO_PRINTF2(_L("Interface at implementation.addr = 0x%08x is deleted"), iImp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    68
	delete iImp;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    69
	iImp = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    70
	REComSession::FinalClose();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    71
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    72
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    73
CBoundCLPushStep_1::~CBoundCLPushStep_1()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    74
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    75
* Destructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    76
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    77
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    78
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    79
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    80
CBoundCLPushStep_1::CBoundCLPushStep_1()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    81
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    82
* Constructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    83
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    84
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    85
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    86
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    87
TVerdict CBoundCLPushStep_1::doTestStepL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    88
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    89
* @return - TVerdict code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    90
* Override of base class pure virtual
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    91
* Our implementation only gets called if the base class doTestStepPreambleL() did
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    92
* not leave. That being the case, the current test result value will be EPass.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    93
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    94
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    95
	//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    96
	// CWapBoundCLPushService
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    97
	// 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    98
	INFO_PRINTF1(_L("CreateImplementation - CWapBoundCLPushService"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    99
	INFO_PRINTF1(_L("Calling old NewL() method"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   100
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   101
	TInt trapValue; 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   102
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   103
	SetTestStepResult(EFail);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   104
	TRAP(trapValue, iImp = CWapBoundCLPushService::NewL());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   105
	if(!trapValue)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   106
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   107
		INFO_PRINTF2(_L("Interface is loaded: implementation.addr = 0x%08x"), iImp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   108
		UnloadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   109
		iImp = LoadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   110
		if(iImp)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   111
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   112
			INFO_PRINTF1(_L("CreateImplementation - OK"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   113
			SetTestStepResult(EPass);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   114
			UnloadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   115
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   116
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   117
	return TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   118
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   119
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   120
CBoundCLPushStep_2::CBoundCLPushStep_2()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   121
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   122
* Constructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   123
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   124
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   125
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   126
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   127
CBoundCLPushStep_2::~CBoundCLPushStep_2() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   128
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   129
* Destructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   130
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   131
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   132
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   133
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   134
TVerdict CBoundCLPushStep_2::doTestStepL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   135
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   136
* Test Connect methoths 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   137
* @return - TVerdict code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   138
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   139
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   140
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   141
	INFO_PRINTF1(_L("BOUNDCL-PUSH: Testing Connect"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   142
	if(TestStepResult() == EPass )
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   143
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   144
		SetTestStepResult(EFail);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   145
		iImp = LoadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   146
		if(iImp)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   147
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   148
			TInt bearer, port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   149
			TInt error	= KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   150
			TBool secure= EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   151
			TBool reconnect= EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   152
			SetLastError(KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   153
			TBool delay = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   154
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   155
			if(GetIntFromConfig(ConfigSection(), KWapBearer, bearer)) iBearer = (Wap::TBearer)bearer;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   156
			if(GetIntFromConfig(ConfigSection(), KWapLocalPort, port)) iLocalPort = (Wap::TPort)port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   157
			if(GetIntFromConfig(ConfigSection(), KWapExError, error)) SetExpectedError(error);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   158
			if(GetBoolFromConfig(ConfigSection(), KWapSecure, secure)) iSecure = secure;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   159
			if(GetBoolFromConfig(ConfigSection(),_L("Reconnect"), reconnect)) iReconnect = reconnect;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   160
			if(GetBoolFromConfig(ConfigSection(),KWapDelayPortClosure, delay)) iDelayPortClosure = delay;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   161
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   162
			if(UseSimTsy())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   163
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   164
				GetIntFromConfig(ConfigSection(), KWapSIMTSYState, iSimTsyState);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   165
				User::LeaveIfError(RProperty::Set(KUidPSSimTsyCategory, KPSSimTsyTestNumber, iSimTsyState));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   166
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   167
			User::LeaveIfError(RProperty::Set(KUidSystemCategory, KUidPhonePwr.iUid, ESAPhoneOn));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   168
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   169
			SetState(EConnect);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   170
			iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   171
			ShowConnectionInfo();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   172
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   173
			StartScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   174
			UnloadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   175
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   176
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   177
	return TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   178
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   179
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   180
TInt CBoundCLPushStep_2::CallStateMachine()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   181
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   182
	TInt err = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   183
	INFO_PRINTF2(_L("CallStateMachine: state [%d]"), State());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   184
	switch(iState)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   185
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   186
		case EConnect:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   187
			INFO_PRINTF1(_L("EConnect"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   188
			err = iImp->Connect(iBearer, (Wap::TPort)iLocalPort, iSecure);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   189
			INFO_PRINTF2(_L("Connection completed with code = %d"), err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   190
			if( err == KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   191
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   192
				if(iReconnect)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   193
					{ 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   194
					INFO_PRINTF1(_L("Second connect"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   195
					iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   196
					break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   197
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   198
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   199
			SetState(EFinish);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   200
			SetLastError(err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   201
			iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   202
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   203
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   204
		case EFinish:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   205
			// it's necessary to delay port closure, let the other concurrent test step
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   206
			// can fail opening the same port with expected error EPortAlreadyBound (-5498)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   207
			if (iDelayPortClosure)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   208
				User::After(5000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   209
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   210
			INFO_PRINTF1(_L("EFinish"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   211
			if(GetLastError() == GetExpectedError()) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   212
				SetTestStepResult(EPass);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   213
			else 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   214
				SetTestStepResult(EFail);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   215
			SetState(EIdle); 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   216
			StopScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   217
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   218
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   219
		case EIdle:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   220
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   221
			INFO_PRINTF2(_L("Error: EIdle or unknown state %d"), State());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   222
			SetTestStepResult(EFail);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   223
			StopScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   224
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   225
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   226
	return (0);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   227
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   228
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   229
CBoundCLPushStep_3::CBoundCLPushStep_3()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   230
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   231
* Constructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   232
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   233
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   234
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   235
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   236
CBoundCLPushStep_3::~CBoundCLPushStep_3() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   237
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   238
* Destructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   239
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   240
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   241
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   242
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   243
TVerdict CBoundCLPushStep_3::doTestStepL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   244
/*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   245
* Test the BoundCLPush APIs in unconnected state.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   246
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   247
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   248
	INFO_PRINTF1(_L("BoundCLPush. Requests without connection"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   249
	// check preamble result
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   250
	TVerdict verdict = TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   251
	if (verdict==EPass)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   252
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   253
		TInt err, ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   254
		iImp = LoadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   255
		if (!iImp)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   256
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   257
			ERR_PRINTF1(_L("Unable to load BoundCLPush Interface"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   258
			verdict = EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   259
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   260
		else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   261
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   262
			GetIntFromConfig(ConfigSection(),KWapExError,(TInt&)iExError);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   263
			ShowConnectionInfo();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   264
			TRequestStatus reqStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   265
			iImp->AwaitPush(iRecvHeadersBuf, iRecvBodyBuf, iTransactionIdPckg, reqStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   266
			TRAP(ret, TEST_CHECKL(reqStatus.Int(), iExError, _L("AwaitPush Fails not as expected")))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   267
				if (ret) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   268
					verdict = EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   269
				else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   270
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   271
					Wap::TPort port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   272
					err=iImp->GetLocalPort(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   273
					TRAP(ret, TEST_CHECKL(err, iExError, _L("GetLocalPort Fails not as expected")))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   274
						if (ret)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   275
							verdict = EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   276
						else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   277
							{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   278
							HBufC8* localHost;					
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   279
							err=iImp->GetLocalAddress(localHost);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   280
							TRAP(ret, TEST_CHECKL(err, iExError, _L("GetLocalAddress Fails not as expected")))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   281
								if (ret) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   282
									verdict = EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   283
								else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   284
									{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   285
									err=iImp->GetBearer(iBearer);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   286
									TRAP(ret, TEST_CHECKL(err, iExError, _L("GetBearer Fails not as expected")))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   287
										if (ret) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   288
											verdict = EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   289
										else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   290
											{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   291
											HBufC8* host;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   292
											err=iImp->GetServerAddress(host);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   293
											TRAP(ret, TEST_CHECKL(err, iExError, _L("GetServerAddress Fails not as expected")))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   294
												if (ret) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   295
													verdict = EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   296
											}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   297
									}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   298
							}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   299
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   300
				UnloadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   301
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   302
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   303
	if (verdict==EPass)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   304
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   305
		INFO_PRINTF1(_L("BoundCLPush. Requests Fail as expected"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   306
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   307
	SetTestStepResult(verdict);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   308
	return TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   309
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   310
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   311
TInt CBoundCLPushStep_3::CallStateMachine()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   312
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   313
	return (0);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   314
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   315
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   316
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   317
CBoundCLPushStep_4::CBoundCLPushStep_4()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   318
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   319
* Constructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   320
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   321
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   322
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   323
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   324
CBoundCLPushStep_4::~CBoundCLPushStep_4() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   325
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   326
* Destructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   327
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   328
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   329
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   330
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   331
TVerdict CBoundCLPushStep_4::doTestStepL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   332
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   333
* Test receiving PDU data over UDP
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   334
* The test is run concurently with CBoundCLPushStep_9 test. CBoundCLPushStep_4 waits for push message whilst 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   335
* CBoundCLPushStep_9 sends a push message over UDP using loopback. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   336
* The test pair is used to test two cases (dependent on configuration read for CBoundCLPushStep_9):
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   337
* - sending PDU data that is smaller than the allocated buffer on the receiving side (<=1024)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   338
* - sending PDU data that is larger than the allocated buffer on the receiving side and needs reallocation (>1024)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   339
* @return - TVerdict code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   340
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   341
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   342
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   343
	INFO_PRINTF1(_L("BOUND-CLPUSH: Connect-AwaitPush"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   344
	INFO_PRINTF1(_L("Receiving PDU over UDP from a concurrent test... "));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   345
	if(TestStepResult() == EPass )
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   346
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   347
		SetTestStepResult(EFail);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   348
		iImp = LoadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   349
		if(iImp)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   350
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   351
			SetLastError(KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   352
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   353
			TInt bearer, port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   354
			TInt error = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   355
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   356
			if(GetIntFromConfig(ConfigSection(),KWapBearer, bearer))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   357
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   358
				iBearer = static_cast<Wap::TBearer>(bearer);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   359
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   360
			if(GetIntFromConfig(ConfigSection(),KWapLocalPort, port)) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   361
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   362
				iLocalPort = static_cast<Wap::TPort>(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   363
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   364
			if(GetIntFromConfig(ConfigSection(),KWapExError, error))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   365
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   366
				SetExpectedError(error);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   367
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   368
			GetBoolFromConfig(ConfigSection(), KMiddleCancel, iMiddleCancel);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   369
			GetBoolFromConfig(ConfigSection(), KMultiReadCancel, iMultiReadCancel);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   370
			TInt headerLength, bufLength; 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   371
			if(GetIntFromConfig(ConfigSection(),KWapWSPRecvHeaderLength, headerLength))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   372
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   373
				iHeaderRecvBufLength=static_cast<TUint16>(headerLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   374
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   375
			if(GetIntFromConfig(ConfigSection(),KWapWSPRecvBodyLength, bufLength))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   376
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   377
				iBodyRecvBufLength=static_cast<TUint16>(bufLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   378
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   379
			iRecvHeaders = HBufC8::NewL(iHeaderRecvBufLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   380
			iRecvBody = HBufC8::NewL(iBodyRecvBufLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   381
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   382
			User::LeaveIfError(RProperty::Set(KUidSystemCategory, KUidPhonePwr.iUid, ESAPhoneOn));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   383
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   384
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   385
			if(UseSimTsy())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   386
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   387
				GetIntFromConfig(ConfigSection(),KWapSIMTSYState, iSimTsyState);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   388
				User::LeaveIfError(RProperty::Set(KUidPSSimTsyCategory, KPSSimTsyTestNumber, iSimTsyState));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   389
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   390
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   391
						
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   392
			SetState(EConnect);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   393
			iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   394
			ShowConnectionInfo();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   395
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   396
			StartScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   397
			delete iRecvBody;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   398
			iRecvBody=NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   399
			delete iRecvHeaders;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   400
			iRecvHeaders=NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   401
			UnloadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   402
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   403
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   404
	return TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   405
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   406
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   407
TInt CBoundCLPushStep_4::CallStateMachine()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   408
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   409
	TVerdict verdict = EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   410
	TInt err = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   411
	TInt activate = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   412
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   413
	INFO_PRINTF2(_L("CallStateMachine:  state [%d]"), State());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   414
	switch(iState)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   415
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   416
		case EConnect:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   417
			INFO_PRINTF1(_L("EConnect"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   418
			err = iImp->Connect(iBearer, iLocalPort, EFalse);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   419
			INFO_PRINTF2(_L("Connection completed with code = %d"), err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   420
			if( err == KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   421
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   422
				if(iBearer != Wap::EIP)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   423
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   424
					TRAP(err, WaitForInitializeL());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   425
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   426
				iRecvHeadersBuf.Set(iRecvHeaders->Des());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   427
				iRecvBodyBuf.Set(iRecvBody->Des());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   428
				iImp->AwaitPush(iRecvHeadersBuf, iRecvBodyBuf, iTransactionIdPckg, *iStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   429
				INFO_PRINTF1(_L("Start AwaitingPush....."));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   430
				activate = 1;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   431
				if (!iMiddleCancel)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   432
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   433
					SetState(EAwaitPush);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   434
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   435
				else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   436
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   437
					INFO_PRINTF1(_L("Cancel AwaitPush"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   438
					iImp->CancelAwaitPush();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   439
					SetState(EFinish);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   440
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   441
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   442
			else 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   443
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   444
				SetState(EFinish);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   445
				iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   446
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   447
			SetLastError(err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   448
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   449
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   450
		case EAwaitPush:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   451
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   452
			INFO_PRINTF1(_L("EAwaitPush"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   453
			if(iStatus->Int() != KErrNone && iStatus->Int()!=Wap::EMoreData) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   454
				// AwaitPush failed
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   455
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   456
				INFO_PRINTF1(_L("AwaitPush failed"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   457
				SetLastError(iStatus->Int());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   458
				SetState(EFinish);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   459
				iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   460
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   461
			else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   462
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   463
				iMaxWspHeaderRecvBuffer.Append(iRecvHeadersBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   464
				iMaxWspDataRecvBuffer.Append(iRecvBodyBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   465
				if (iStatus->Int()==Wap::EMoreData)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   466
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   467
					iImp->AwaitPush(iRecvHeadersBuf, iRecvBodyBuf, iTransactionIdPckg, *iStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   468
					activate = 1;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   469
					if (!iMultiReadCancel)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   470
						{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   471
						SetState(EAwaitPush);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   472
						}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   473
					else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   474
						{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   475
						INFO_PRINTF1(_L("Cancel Receive in EMutipleReceive state"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   476
						iImp->CancelAwaitPush();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   477
						SetState(EFinish);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   478
						}					
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   479
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   480
				else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   481
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   482
					SetLastError(iStatus->Int());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   483
					iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   484
					SetState(EFinish);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   485
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   486
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   487
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   488
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   489
		case EFinish:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   490
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   491
			INFO_PRINTF1(_L("EFinish"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   492
			if(iStatus->Int() != KErrNone) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   493
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   494
				SetLastError(iStatus->Int());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   495
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   496
			verdict = (GetLastError() == GetExpectedError())?EPass:EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   497
			if (verdict==EPass && !iMiddleCancel && !iMultiReadCancel)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   498
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   499
				iImp->CancelAwaitPush();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   500
				INFO_PRINTF1(_L("Headers:"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   501
				DumpBuf(iMaxWspHeaderRecvBuffer);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   502
				INFO_PRINTF1(_L("Body"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   503
				DumpBuf(iMaxWspDataRecvBuffer);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   504
				if (verdict==EPass)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   505
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   506
					HBufC8* buf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   507
					iImp->GetServerAddress(buf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   508
					verdict = (buf->Match(iRemoteHost)!=KErrNotFound)?EPass:EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   509
					delete buf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   510
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   511
				if (verdict==EPass)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   512
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   513
					Wap::TPort port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   514
					iImp->GetLocalPort(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   515
					verdict = (port == iLocalPort)?EPass:EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   516
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   517
				if (verdict==EPass)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   518
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   519
					Wap::TBearer bearer;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   520
					iImp->GetBearer(bearer);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   521
					verdict = (bearer == iBearer)?EPass:EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   522
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   523
				if (verdict==EPass)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   524
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   525
					//This test can not perform.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   526
					HBufC8* buf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   527
					iImp->GetLocalAddress(buf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   528
					delete buf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   529
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   530
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   531
			SetTestStepResult(verdict);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   532
			SetState(EIdle);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   533
			StopScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   534
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   535
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   536
		case EIdle:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   537
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   538
			INFO_PRINTF2(_L("Error: EIdle or unknown state %d"), State());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   539
			SetTestStepResult(verdict);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   540
			StopScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   541
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   542
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   543
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   544
		return (activate);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   545
}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   546
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   547
CBoundCLPushStep_5::CBoundCLPushStep_5()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   548
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   549
* Constructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   550
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   551
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   552
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   553
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   554
CBoundCLPushStep_5::~CBoundCLPushStep_5() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   555
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   556
* Destructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   557
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   558
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   559
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   560
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   561
TVerdict CBoundCLPushStep_5::doTestStepL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   562
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   563
* Test Cancel 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   564
* @return - TVerdict code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   565
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   566
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   567
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   568
	INFO_PRINTF1(_L("BOUNDCL-PUSH: Testing Cancel"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   569
	if(TestStepResult() == EPass )
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   570
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   571
		SetTestStepResult(EFail);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   572
		iImp = LoadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   573
		if(iImp)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   574
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   575
			TInt bearer, port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   576
			TInt error	= KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   577
			TBool secure= EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   578
			TBool reconnect= EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   579
			SetLastError(KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   580
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   581
			if(GetIntFromConfig(ConfigSection(),KWapBearer, bearer)) iBearer = (Wap::TBearer)bearer;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   582
			if(GetIntFromConfig(ConfigSection(),KWapLocalPort, port)) iLocalPort = (Wap::TPort)port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   583
			if(GetIntFromConfig(ConfigSection(), KWapExError, error)) SetExpectedError(error);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   584
			if(GetBoolFromConfig(ConfigSection(), KWapSecure, secure)) iSecure = secure;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   585
			if(GetBoolFromConfig(ConfigSection(),_L("Reconnect"), reconnect)) iReconnect = reconnect;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   586
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   587
			ShowConnectionInfo();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   588
			error = iImp->Connect(iBearer, iLocalPort, iSecure);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   589
			INFO_PRINTF2(_L("Connection completed with code = %d"), error);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   590
			if( error == KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   591
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   592
				TBuf8<100> header, body;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   593
				TPckgBuf<TUint8> pushIdPckg;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   594
				TRequestStatus reqStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   595
				iImp->AwaitPush(header, body, pushIdPckg, reqStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   596
				SetState(EAwaitPush);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   597
				StartScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   598
				iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   599
				if(reqStatus==KErrCancel)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   600
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   601
					SetTestStepResult(EPass);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   602
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   603
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   604
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   605
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   606
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   607
	return TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   608
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   609
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   610
TInt CBoundCLPushStep_5::CallStateMachine()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   611
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   612
	INFO_PRINTF2(_L("CallStateMachine: state [%d]"), State());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   613
	switch(iState)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   614
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   615
		case EAwaitPush:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   616
			INFO_PRINTF1(_L("EAwaitPush"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   617
			iImp->CancelAwaitPush();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   618
			SetState(EFinish);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   619
			iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   620
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   621
		case EFinish:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   622
			INFO_PRINTF1(_L("EFinish"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   623
			SetState(EIdle);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   624
			StopScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   625
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   626
		case EIdle:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   627
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   628
			INFO_PRINTF2(_L("Error: EIdle or unknown state %d"), State());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   629
			SetTestStepResult(EFail);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   630
			StopScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   631
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   632
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   633
	return (0);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   634
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   635
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   636
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   637
CBoundCLPushStep_6::CBoundCLPushStep_6() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   638
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   639
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   640
CBoundCLPushStep_6::~CBoundCLPushStep_6() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   641
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   642
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   643
TVerdict CBoundCLPushStep_6::doTestStepL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   644
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   645
	return TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   646
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   647
TInt CBoundCLPushStep_6::CallStateMachine()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   648
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   649
	return (0);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   650
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   651
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   652
CBoundCLPushStep_7::CBoundCLPushStep_7() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   653
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   654
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   655
CBoundCLPushStep_7::~CBoundCLPushStep_7() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   656
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   657
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   658
TVerdict CBoundCLPushStep_7::doTestStepL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   659
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   660
	INFO_PRINTF1(_L("BOUND-CLPUSH: Connect-AwaitPush-AwaitPush"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   661
	if(TestStepResult() == EPass )
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   662
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   663
		SetTestStepResult(EFail);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   664
		iImp = LoadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   665
		if(iImp)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   666
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   667
			SetLastError(KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   668
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   669
			TInt bearer, port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   670
			TInt error = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   671
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   672
			if(GetIntFromConfig(ConfigSection(),KWapBearer, bearer)) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   673
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   674
				iBearer = static_cast<Wap::TBearer>(bearer);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   675
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   676
			if(GetIntFromConfig(ConfigSection(),KWapLocalPort, port)) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   677
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   678
				iLocalPort = static_cast<Wap::TPort>(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   679
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   680
			if(GetIntFromConfig(ConfigSection(),KWapExError, error)) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   681
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   682
				SetExpectedError(error);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   683
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   684
			TInt headerLength, bufLength; 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   685
			if(GetIntFromConfig(ConfigSection(),KWapWSPRecvHeaderLength, headerLength))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   686
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   687
				iHeaderRecvBufLength=static_cast<TUint16>(headerLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   688
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   689
			if(GetIntFromConfig(ConfigSection(),KWapWSPRecvBodyLength, bufLength))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   690
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   691
				iBodyRecvBufLength=static_cast<TUint16>(bufLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   692
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   693
			iRecvHeaders = HBufC8::NewL(iHeaderRecvBufLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   694
			iRecvBody = HBufC8::NewL(iBodyRecvBufLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   695
			SetState(EConnect);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   696
			iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   697
			ShowConnectionInfo();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   698
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   699
			StartScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   700
			delete iRecvBody;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   701
			iRecvBody=NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   702
			delete iRecvHeaders;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   703
			iRecvHeaders=NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   704
			UnloadInterface();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   705
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   706
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   707
	return TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   708
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   709
TInt CBoundCLPushStep_7::CallStateMachine()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   710
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   711
	TVerdict verdict = EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   712
	TInt err = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   713
	TInt activate = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   714
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   715
	INFO_PRINTF2(_L("CallStateMachine: state [%d]"), State());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   716
	switch(iState)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   717
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   718
		case EConnect:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   719
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   720
			INFO_PRINTF1(_L("EConnect"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   721
			err = iImp->Connect(iBearer, iLocalPort, EFalse);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   722
			INFO_PRINTF2(_L("Connection completed with code = %d"), err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   723
			if( err == KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   724
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   725
				iRecvHeadersBuf.Set(iRecvHeaders->Des());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   726
				iRecvBodyBuf.Set(iRecvBody->Des());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   727
				TRequestStatus reqStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   728
				iImp->AwaitPush(iRecvHeadersBuf, iRecvBodyBuf, iTransactionIdPckg, reqStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   729
				iImp->AwaitPush(iRecvHeadersBuf, iRecvBodyBuf, iTransactionIdPckg, *iStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   730
				INFO_PRINTF1(_L("AwaitPush"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   731
				activate = 1;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   732
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   733
			else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   734
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   735
				iControl->ReStart();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   736
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   737
			SetLastError(err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   738
			SetState(EFinish);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   739
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   740
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   741
		case EFinish:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   742
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   743
			INFO_PRINTF1(_L("EFinish"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   744
			iImp->CancelAwaitPush();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   745
			if(iStatus->Int() != KErrNone) 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   746
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   747
				SetLastError(iStatus->Int());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   748
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   749
			verdict = (GetLastError() == GetExpectedError())?EPass:EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   750
			SetTestStepResult(verdict);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   751
			SetState(EIdle);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   752
			StopScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   753
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   754
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   755
		case EIdle:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   756
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   757
			INFO_PRINTF2(_L("Error: EIdle or unknown state [%d]"), State());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   758
			SetTestStepResult(verdict);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   759
			StopScheduler();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   760
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   761
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   762
	return (activate);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   763
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   764
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   765
CBoundCLPushStep_8::CBoundCLPushStep_8() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   766
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   767
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   768
CBoundCLPushStep_8::~CBoundCLPushStep_8() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   769
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   770
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   771
TVerdict CBoundCLPushStep_8::doTestStepL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   772
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   773
*	@return - TVerdict code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   774
*	Wrong parameter values for Bound CL Push API:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   775
*	- Wrong TUid on construction
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   776
*	- Connect to wrong bearer (already implemented in test 2)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   777
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   778
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   779
	INFO_PRINTF1(_L("CreateImplementation with wrong Uid- CWapBoundCLPushService"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   780
	if(TestStepResult() == EPass )
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   781
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   782
		TInt error;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   783
		if(GetIntFromConfig(ConfigSection(),KWapExError2, error))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   784
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   785
			iExError2=error;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   786
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   787
		TInt trapValue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   788
		
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   789
		TUid invalidInterfaceUid = {0x00000000}; 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   790
		
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   791
		INFO_PRINTF2(_L("Calling new NewL(0x%08X) method"), invalidInterfaceUid);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   792
		TRAP(trapValue, iImp = CWapBoundCLPushService::NewL(invalidInterfaceUid));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   793
		TVerdict verdict = (trapValue == iExError2)?EPass:EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   794
		if (verdict==EPass)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   795
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   796
			INFO_PRINTF2(_L("CreateImplementation with wrong Uid- Failed as expected with error %d"),trapValue);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   797
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   798
		SetTestStepResult(verdict);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   799
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   800
	return TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   801
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   802
TInt CBoundCLPushStep_8::CallStateMachine()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   803
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   804
	return (0);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   805
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   806
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   807
CBoundCLPushStep_9::CBoundCLPushStep_9() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   808
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   809
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   810
CBoundCLPushStep_9::~CBoundCLPushStep_9() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   811
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   812
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   813
TVerdict CBoundCLPushStep_9::doTestStepL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   814
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   815
* Test sending PDU data over UDP
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   816
* Test should be run concurently with CBoundCLPushStep_4 test. CBoundCLPushStep_4 waits for push message whilst 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   817
* CBoundCLPushStep_9 sends a push message over UDP using loopback. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   818
* The test pair is used to test two cases (dependent on configuration read for CBoundCLPushStep_9):
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   819
* - sending PDU data that is smaller than the allocated buffer on the receiving side (<=1024)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   820
* - sending PDU data that is larger than the allocated buffer on the receiving side and needs reallocation (>1024)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   821
* @return - TVerdict code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   822
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   823
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   824
	INFO_PRINTF1(_L("BOUND-CLPUSH: Sending Push Message"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   825
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   826
	if(TestStepResult() == EPass )
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   827
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   828
		User::After(20000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   829
		SetTestStepResult(EFail);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   830
		SetLastError(KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   831
		TInt error = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   832
		/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   833
		Getting information from config file
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   834
		Local port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   835
		Remote port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   836
		Local address
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   837
		Remote address
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   838
		Size of data to be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   839
		*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   840
		GetIntFromConfig(ConfigSection(),KLocalPort, iLclPort);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   841
		GetIntFromConfig(ConfigSection(),KRemotePort, iRmtPort);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   842
		TPtrC temp;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   843
		if(GetStringFromConfig(ConfigSection(),KWapLocalHost, temp))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   844
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   845
			error = iLocalAddr.Input(temp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   846
			if(error)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   847
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   848
				User::Leave(error);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   849
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   850
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   851
		if(GetStringFromConfig(ConfigSection(),KWapRemoteHost, temp ))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   852
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   853
			error = iRemoteAddr.Input(temp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   854
			if(error)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   855
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   856
				User::Leave(error);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   857
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   858
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   859
//		error = GetStringFromConfig(ConfigSection(),KWapData, temp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   860
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   861
		RFs fS;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   862
		RFile file;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   863
		User::LeaveIfError(fS.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   864
		_LIT(KPduFilename,"z:\\testdata\\configs\\pushpdu.bin");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   865
		_LIT(KPDUDataSize,"Data_Size");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   866
		
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   867
		User::LeaveIfError(file.Open(fS, KPduFilename , EFileStream | EFileRead));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   868
		/* Read PDU from the file */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   869
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   870
		TInt dataSize(1024);        
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   871
		GetIntFromConfig(ConfigSection(),KPDUDataSize, dataSize);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   872
		iSendBuffPtr = HBufC8::NewL(dataSize);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   873
		TPtr8 tmpbuf = iSendBuffPtr->Des();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   874
		User::LeaveIfError(file.Read(tmpbuf));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   875
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   876
		file.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   877
		fS.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   878
		/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   879
		Settings
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   880
		*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   881
		iLocalAddr.SetPort(iLclPort);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   882
		iRemoteAddr.SetPort(iRmtPort);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   883
//		iSendBuffPtr = HBufC8::NewL(temp.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   884
//		TPtr8 tmp = iSendBuffPtr->Des();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   885
//		tmp.Copy(temp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   886
		INFO_PRINTF2(_L("Sending PDU of size %d over UDP to a concurrent test... "), dataSize);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   887
		/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   888
		socket server 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   889
		*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   890
		RSocketServ socketServer;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   891
	    User::LeaveIfError(socketServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   892
		CleanupClosePushL(socketServer);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   893
		RSocket sock;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   894
		User::LeaveIfError(sock.Open(socketServer, KAfInet, KSockDatagram, KProtocolInetUdp));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   895
		CleanupClosePushL(sock);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   896
		TRequestStatus status;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   897
		sock.SendTo(iSendBuffPtr->Des(),iRemoteAddr , 0, status);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   898
		User::WaitForRequest(status);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   899
		INFO_PRINTF2(_L("Send Push Message - status = %d"), status.Int());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   900
		User::LeaveIfError(status.Int());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   901
		sock.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   902
		socketServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   903
		CleanupStack::PopAndDestroy(&sock);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   904
		CleanupStack::Pop(&socketServer);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   905
		TVerdict verdict = (status.Int() == KErrNone)?EPass:EFail;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   906
		SetTestStepResult(verdict);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   907
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   908
	return TestStepResult();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   909
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   910
TInt CBoundCLPushStep_9::CallStateMachine()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   911
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   912
			return (0);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   913
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   914
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   915
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   916
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   917