cbsref/csyrefplugins/csy27010/test/Csy27010UnitTest.cpp
author hgs
Mon, 09 Aug 2010 17:35:42 +0100
changeset 58 980b3d0c4069
parent 44 8b72faa1200f
permissions -rw-r--r--
201027_10
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
44
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     1
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     2
// * Copyright 2004 Neusoft America Inc.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     3
// * All rights reserved.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     4
// * This component and the accompanying materials are made available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     5
// * under the terms of the Eclipse Public License v1.0
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     6
// * which accompanies this distribution, and is available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     7
// * at the URL "http://www.eclipse.org/legal/epl-v10.html".
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     8
// *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     9
// * Contributors:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    10
// * Keith Collins (Neusoft America Inc.)  original software development and additional code and modifications.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    11
// * Thomas Gahagen (Neusoft America Inc.)  additional code and modifications.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    12
// * Zhen Yuan (Neusoft America Inc.)  additional code and modifications.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    13
// *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    14
// * Description:  This contains the Unit Tests dealing with CSY 0710 related
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    15
// *               functionality as documented in the project's Unit Test Spec.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    16
// *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    17
// *               The tests may be run either interactively or automatically.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    18
// *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    19
// *               The tests are dependant on a predictable response from
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    20
// *               the BP side according to the test spec.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    21
// *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    22
// *               The automated tests achieve this predictable response by
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    23
// *               using the Tester component.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    24
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    25
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    26
// Csy0710UnitTest.cpp
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    27
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    28
/** @file Csy0710UnitTest.cpp
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    29
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    30
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    31
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    32
#include "Csy27010UnitTest.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    33
#include <exterror.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    34
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    35
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    36
_LIT8(KATCommand1,  "AT+CGMM\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    37
_LIT8(KATCommand2,  "AT+CGMM\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    38
_LIT8(KATCommand3,  "AT+CMUX?\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    39
_LIT8(KATCommand4,  "AT\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    40
_LIT8(KATCommand5,  "AT+CGMI\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    41
_LIT8(KATCommand6,  "AT+CGSN\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    42
_LIT8(KATCommand7,  "AT+CGMR\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    43
_LIT8(KATCommand8,  "AT+CBC\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    44
_LIT8(KATCommand9,  "AT+CSQ\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    45
_LIT8(KATCommand10, "ATS7?\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    46
_LIT8(KATCommand11, "ATS0=5\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    47
_LIT8(KATCommand12, "AT+FCLASS=2.0\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    48
_LIT8(KATCommand13, "AT+CRC=?\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    49
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    50
//_LIT8(KATCommandToCancel, "ABCDEFGHIJKLMNOPQRSTUVWXYZ\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    51
_LIT8(KATCommandToCancel, "AT\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    52
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    53
//-----------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    54
// Helper routines
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    55
//-----------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    56
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    57
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    58
TBool CCsy0710UnitTest::HasTestRangesDefined()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    59
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    60
	return ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    61
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    62
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    63
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    64
//-----------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    65
//-----------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    66
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    67
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    68
//-----------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    69
//-----------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    70
CCsy0710UnitTest* CCsy0710UnitTest::NewL(const TDesC& aUnitTestName,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    71
								 const TDesC& aLogFileName,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    72
							     const TDesC& aTestSpecName,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    73
							     const TDesC& aTestScriptName)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    74
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    75
	CCsy0710UnitTest* self = new(ELeave) CCsy0710UnitTest(aUnitTestName,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    76
				aLogFileName, aTestSpecName, aTestScriptName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    77
	CleanupStack::PushL(self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    78
	self->ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    79
	CleanupStack::Pop();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    80
	return self;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    81
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    82
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    83
CCsy0710UnitTest::~CCsy0710UnitTest()
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
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    88
CCsy0710UnitTest::CCsy0710UnitTest(const TDesC& aUnitTestName,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    89
						   const TDesC& aLogFileName,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    90
						   const TDesC& aTestSpecName,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    91
						   const TDesC& aTestScriptName)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    92
: CUnitTestBase(aUnitTestName, aLogFileName, aTestSpecName, aTestScriptName)
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
void CCsy0710UnitTest::ConstructL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    97
	{	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    98
	CUnitTestBase::ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    99
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   100
	iCmdPortName[0].Copy(_L("gsm0710::1"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   101
	iCmdPortName[1].Copy(_L("gsm0710::2"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   102
	iCmdPortName[2].Copy(_L("gsm0710::3"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   103
	iCmdPortName[3].Copy(_L("gsm0710::4"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   104
	iDataPort1Name.Copy(_L("gsm0710::101"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   105
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   106
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   107
void CCsy0710UnitTest::PrintTestSpecIdentifiers()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   108
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   109
	iTest.Printf(_L("\nCSY 0710 Unit Test\n\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   110
	iTest.Printf(_L("1: CSY A tests\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   111
	iTest.Printf(_L("2: CSY B tests\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   112
	iTest.Printf(_L("3: CSY C tests\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   113
	iTest.Printf(_L("4: CSY D tests\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   114
	iTest.Printf(_L("5: CSY E tests\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   115
	iTest.Printf(_L("6: CSY F tests\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   116
	iTest.Printf(_L("7: CSY G tests\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   117
	iTest.Printf(_L("8: CSY H tests\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   118
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   119
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   120
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   121
void CCsy0710UnitTest::PrintTestDetails(TInt /*aTstSpecNumber*/)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   122
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   123
	// This version prints no helpful info on the screen. Overload this in
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   124
	// your own test class to put out test details for the test spec idenifier
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   125
	// selected
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   126
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   127
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   128
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   129
void CCsy0710UnitTest::RunTestsL(TBool aEndInd,TTestMode aTestMode,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   130
								 TInt& aErrCode, TInt& aLeaveCode, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   131
								 TInt aApiNumber, TInt aTestNumber)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   132
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   133
	switch (aApiNumber)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   134
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   135
		case 0:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   136
			aLeaveCode = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   137
			aErrCode = 8;  // 8 more tests
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   138
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   139
		case 1:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   140
			TRAP(aLeaveCode,aErrCode = CsyAL(aTestNumber));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   141
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   142
		case 2:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   143
			TRAP(aLeaveCode,aErrCode = CsyBL(aTestNumber));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   144
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   145
		case 3:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   146
			TRAP(aLeaveCode,aErrCode = CsyCL(aTestNumber));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   147
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   148
		case 4:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   149
			TRAP(aLeaveCode,aErrCode = CsyDL(aTestNumber));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   150
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   151
		case 5:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   152
			TRAP(aLeaveCode,aErrCode = CsyEL(aTestNumber));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   153
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   154
		case 6:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   155
			TRAP(aLeaveCode,aErrCode = CsyFL(aTestNumber));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   156
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   157
		case 7:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   158
			TRAP(aLeaveCode,aErrCode = CsyGL(aTestNumber));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   159
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   160
		case 8:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   161
			TRAP(aLeaveCode,aErrCode = CsyHL(aTestNumber));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   162
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   163
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   164
			ActionNoMatch(aEndInd,aTestMode,aApiNumber, aTestNumber);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   165
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   166
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   167
	//CloseAllResources();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   168
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   169
//-----------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   170
//-----------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   171
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   172
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   173
TInt CCsy0710UnitTest::CsyAL(TInt aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   174
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   175
 * CSY Information Tests
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   176
 * @param aTstNum test number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   177
 * @return KErrNone or error code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   178
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   179
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   180
	if (aTstNum != 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   181
		iTest.Printf(_L("CSYA-%d\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   182
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   183
	TInt ret = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   184
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   185
	SetTsIdentifier(_L("CSYA"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   186
	SetMethodName(_L("CSYA"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   187
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   188
	switch (aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   189
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   190
		case 0:		// Return how may auto tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   191
			return (4);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   192
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   193
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   194
		case 1:		// Start C32
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   195
			iTest.Printf(_L("Start C32...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   196
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   197
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   198
			ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   199
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   200
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   201
			iTest.Printf(_L("Test 1-1 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   202
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   203
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   204
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   205
		case 2:		// Load and Unload CSY multiple times
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   206
			iTest.Printf(_L("Basic check on something else..\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   207
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   208
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   209
			ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   210
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   211
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   212
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   213
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   214
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   215
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   216
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   217
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   218
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   219
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   220
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   221
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   222
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   223
			iTest.Printf(_L("Test 1-2 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   224
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   225
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   226
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   227
		case 3:		// Open Multiple Sessions to C32
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   228
			iTest.Printf(_L("Open Multiple Sessions to C32...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   229
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   230
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   231
			ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   232
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   233
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   234
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   235
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   236
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   237
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   238
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   239
			TEST(OpenAllCommPorts());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   240
			User::After(5000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   241
			CloseAllCommPorts();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   242
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   243
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   244
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   245
			iTest.Printf(_L("Test 1-3 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   246
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   247
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   248
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   249
		case 4: 		// Check that the phone supports the expected extensions
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   250
			iTest.Printf(_L("Get CSY Info...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   251
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   252
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   253
			ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   254
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   255
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   256
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   257
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   258
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   259
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   260
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   261
			TEST(GetCsyInfo());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   262
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   263
			iCommServer.Close();			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   264
			User::After(5000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   265
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   266
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   267
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   268
					// Manual Tests Follow...
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   269
		case 100:		// Return how many manual tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   270
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   271
			return 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   272
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   273
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   274
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   275
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   276
			iTest.Printf(_L("** Not implemented CSYA-%d **\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   277
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   278
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   279
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   280
	return ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   281
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   282
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   283
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   284
TInt CCsy0710UnitTest::CsyBL(TInt aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   285
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   286
 * CSY Open and Close Logical Ports Tests
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   287
 * @param aTstNum test number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   288
 * @return void
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   289
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   290
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   291
	if (aTstNum != 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   292
		iTest.Printf(_L("CSYB-%d\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   293
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   294
	TInt ret = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   295
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   296
	SetTsIdentifier(_L("CSYB"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   297
	SetMethodName(_L("CSYB"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   298
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   299
	switch (aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   300
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   301
		case 0:		// Return how may auto tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   302
			return (6);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   303
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   304
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   305
		case 1:		// open & close subsessions
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   306
			iTest.Printf(_L("Open & Close Subsessions...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   307
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   308
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   309
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   310
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   311
			ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   312
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   313
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   314
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   315
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   316
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   317
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   318
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   319
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   320
			TEST(OpenAllCommPorts());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   321
			CloseAllCommPorts();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   322
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   323
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   324
			iTest.Printf(_L("Test 2-1 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   325
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   326
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   327
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   328
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   329
		case 2:		// check failure to open comm port	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   330
			iTest.Printf(_L("Check failure to open comm port...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   331
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   332
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   333
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   334
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   335
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   336
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   337
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   338
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   339
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   340
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   341
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   342
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   343
			TEST(OpenCommPortFail());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   344
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   345
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   346
			iTest.Printf(_L("Test 2-2 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   347
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   348
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   349
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   350
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   351
		case 3:		// open many ports
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   352
			iTest.Printf(_L("Open many RComm ports...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   353
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   354
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   355
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   356
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   357
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   358
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   359
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   360
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   361
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   362
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   363
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   364
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   365
			TEST(OpenAllCommPorts());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   366
			User::After(5000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   367
			CloseAllCommPorts();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   368
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   369
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   370
			iTest.Printf(_L("Test 2-3 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   371
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   372
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   373
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   374
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   375
		case 4:		// check ability to open same port twice
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   376
			iTest.Printf(_L("Check ability to open RComm port twice...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   377
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   378
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   379
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   380
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   381
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   382
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   383
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   384
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   385
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   386
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   387
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   388
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   389
			TEST(OpenCmdPortTwice());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   390
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   391
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   392
			iTest.Printf(_L("Test 2-4 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   393
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   394
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   395
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   396
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   397
		case 5:		// open many subsessions at same time
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   398
			iTest.Printf(_L("Open many RComm ports at same time...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   399
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   400
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   401
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   402
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   403
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   404
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   405
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   406
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   407
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   408
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   409
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   410
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   411
			TEST(OpenAllCommPorts());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   412
			User::After(5000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   413
			CloseAllCommPorts();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   414
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   415
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   416
			iTest.Printf(_L("Test 2-5 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   417
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   418
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   419
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   420
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   421
		case 6:		// check failure to open port with an invalid name
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   422
			iTest.Printf(_L("Check failure to open port with invalid name...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   423
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   424
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   425
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   426
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   427
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   428
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   429
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   430
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   431
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   432
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   433
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   434
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   435
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   436
			TEST(OpenCmdPortInvalidName());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   437
			User::After(5000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   438
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   439
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   440
			User::After(1000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   441
			iTest.Printf(_L("Test 2-6 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   442
			User::After(2000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   443
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   444
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   445
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   446
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   447
			// Manual Tests Follow...
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   448
		case 100:		// Return how many manual tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   449
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   450
			return 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   451
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   452
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   453
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   454
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   455
			iTest.Printf(_L("** Not implemented CSYB-%d **\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   456
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   457
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   458
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   459
	return (ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   460
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   461
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   462
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   463
TInt CCsy0710UnitTest::CsyCL(TInt aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   464
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   465
 * CSY Data Transmission Tests.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   466
 * @param aTstNum test number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   467
 * @return void
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   468
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   469
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   470
	if (aTstNum != 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   471
		iTest.Printf(_L("CSYC-%d\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   472
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   473
	TInt ret = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   474
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   475
	SetTsIdentifier(_L("CSYC"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   476
	SetMethodName(_L("CSYC"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   477
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   478
	switch (aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   479
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   480
		case 0:		// Return how may auto tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   481
			return (4);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   482
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   483
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   484
		case 1:		// Check that information can be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   485
			iTest.Printf(_L("Send command on Comm Port...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   486
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   487
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   488
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   489
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   490
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   491
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   492
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   493
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   494
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   495
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   496
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   497
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   498
			TEST(SendCmdOneCommPort(0));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   499
			User::After(1000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   500
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   501
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   502
			iTest.Printf(_L("Test 3-1 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   503
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   504
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   505
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   506
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   507
		case 2:		// Check that information can be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   508
			iTest.Printf(_L("Send multiple commands on Comm Port...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   509
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   510
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   511
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   512
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   513
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   514
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   515
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   516
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   517
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   518
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   519
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   520
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   521
			SendCmdsOneCommPort(0);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   522
			User::After(1000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   523
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   524
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   525
			iTest.Printf(_L("Test 3-2 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   526
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   527
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   528
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   529
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   530
		case 3:		// check BP ack failure
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   531
			iTest.Printf(_L("Test 3-3 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   532
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   533
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   534
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   535
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   536
		case 4:		// Check write cancel on outstanding cmd
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   537
			iTest.Printf(_L("Cancel Write Request on Comm Port...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   538
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   539
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   540
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   541
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   542
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   543
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   544
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   545
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   546
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   547
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   548
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   549
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   550
			CancelWriteOneCommPort(0);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   551
			User::After(1000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   552
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   553
			// common exit test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   554
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   555
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   556
			iTest.Printf(_L("Test 3-4 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   557
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   558
			return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   559
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   560
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   561
			// Manual Tests Follow...
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   562
		case 100:		// Return how many manual tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   563
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   564
			return 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   565
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   566
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   567
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   568
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   569
			iTest.Printf(_L("** Not implemented CSYC-%d **\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   570
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   571
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   572
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   573
	return (ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   574
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   575
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   576
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   577
TInt CCsy0710UnitTest::CsyDL(TInt aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   578
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   579
 * CSY Tests for receive data on channels.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   580
 * @param aTstNum test number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   581
 * @return KErrNone or error code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   582
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   583
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   584
	TInt ret = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   585
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   586
	if (aTstNum != 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   587
		iTest.Printf(_L("CSYD-%d\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   588
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   589
	SetTsIdentifier(_L("CSYD"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   590
	SetMethodName(_L("CSYD"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   591
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   592
	switch (aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   593
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   594
		case 0:		// Return how may auto tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   595
			return (2);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   596
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   597
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   598
		case 1:		// Check that data can be received
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   599
			iTest.Printf(_L("Recv Data on Comm Port...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   600
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   601
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   602
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   603
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   604
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   605
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   606
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   607
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   608
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   609
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   610
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   611
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   612
			ret = iCommPort[0].Open(iCommServer, iCmdPortName[0], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   613
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   614
			TEST(RecvDataOneCommPort(0));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   615
			iCommPort[0].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   616
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   617
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   618
			iTest.Printf(_L("Test 4-1 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   619
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   620
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   621
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   622
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   623
		case 2:		// Check that data is received and given to the correct port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   624
			iTest.Printf(_L("Recv Data and Route to Correct Port...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   625
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   626
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   627
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   628
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   629
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   630
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   631
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   632
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   633
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   634
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   635
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   636
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   637
			ret = iCommPort[0].Open(iCommServer, iCmdPortName[0], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   638
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   639
			ret = iCommPort[1].Open(iCommServer, iCmdPortName[1], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   640
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   641
			ret = iCommPort[2].Open(iCommServer, iCmdPortName[1], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   642
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   643
			ret = iCommPort[3].Open(iCommServer, iCmdPortName[1], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   644
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   645
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   646
			TEST(RecvDataOneCommPort(0));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   647
			TEST(RecvDataOneCommPort(1));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   648
			TEST(RecvDataOneCommPort(2));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   649
			TEST(RecvDataOneCommPort(3));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   650
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   651
			ret = iCommPort[4].Open(iCommServer, iDataPort1Name, ECommShared); //data port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   652
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   653
			TEST(RecvDataOneCommPort(4)); //newly open port will take away the control of the dlc
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   654
			iCommPort[4].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   655
			// should return control of dlc
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   656
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   657
			TEST(RecvDataOneCommPort(0));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   658
			TEST(RecvDataOneCommPort(1));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   659
			TEST(RecvDataOneCommPort(2));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   660
			TEST(RecvDataOneCommPort(3));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   661
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   662
			iCommPort[3].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   663
			iCommPort[2].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   664
			iCommPort[1].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   665
			iCommPort[0].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   666
			User::After(1000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   667
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   668
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   669
			iTest.Printf(_L("Test 4-2 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   670
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   671
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   672
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   673
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   674
			// Manual Tests Follow...
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   675
		case 100:		// Return how many manual tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   676
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   677
			return 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   678
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   679
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   680
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   681
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   682
			iTest.Printf(_L("** Not implemented CSYD-%d **\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   683
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   684
		}		
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   685
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   686
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   687
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   688
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   689
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   690
TInt CCsy0710UnitTest::CsyEL(TInt aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   691
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   692
 * CSY Tests for flow control of data on logical ports.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   693
 * @param aTstNum test number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   694
 * @return KErrNone or error code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   695
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   696
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   697
	TInt ret = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   698
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   699
	if (aTstNum != 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   700
		iTest.Printf(_L("CSYE-%d\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   701
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   702
	SetTsIdentifier(_L("CSYE"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   703
	SetMethodName(_L("CSYE"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   704
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   705
	switch (aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   706
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   707
		case 0:		// Return how may auto tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   708
			return (1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   709
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   710
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   711
		case 1:		// Check that flow control signals correct port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   712
			iTest.Printf(_L("Verify Flow Control Signals to Correct Port...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   713
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   714
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   715
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   716
			TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   717
            ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   718
            if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   719
                TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   720
			TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   721
			ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   722
			if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   723
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   724
			// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   725
			ret = iCommPort[0].Open(iCommServer, iCmdPortName[0], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   726
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   727
			ret = iCommPort[1].Open(iCommServer, iCmdPortName[1], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   728
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   729
			ret = iCommPort[2].Open(iCommServer, iCmdPortName[2], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   730
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   731
			ret = iCommPort[3].Open(iCommServer, iCmdPortName[3], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   732
			if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   733
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   734
			TEST(VerifyFlowControl(0));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   735
			TEST(VerifyFlowControl(1));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   736
			TEST(VerifyFlowControl(2));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   737
			TEST(VerifyFlowControl(3));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   738
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   739
			iCommPort[3].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   740
			iCommPort[2].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   741
			iCommPort[1].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   742
			iCommPort[0].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   743
			User::After(1000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   744
			iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   745
			iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   746
			iTest.Printf(_L("Test 5-1 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   747
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   748
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   749
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   750
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   751
			// Manual Tests Follow...
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   752
		case 100:		// Return how many manual tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   753
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   754
			return 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   755
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   756
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   757
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   758
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   759
			iTest.Printf(_L("** Not implemented CSYE-%d **\n"), aTstNum);
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
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   763
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   764
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   765
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   766
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   767
TInt CCsy0710UnitTest::CsyFL(TInt aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   768
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   769
 * CSY Tests for 3GPP 27.010 compliance.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   770
 * @param aTstNum test number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   771
 * @return KErrNone or error code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   772
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   773
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   774
	if (aTstNum != 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   775
		iTest.Printf(_L("CSYF-%d\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   776
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   777
	SetTsIdentifier(_L("CSYF"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   778
	SetMethodName(_L("CSYF"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   779
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   780
	iTest.Printf(_L("Verify 3GPP 27.010 Compliance\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   781
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   782
	switch (aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   783
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   784
		case 0:		// Return how may auto tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   785
			return (8);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   786
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   787
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   788
		case 1:		// Check that AT+CMUX is sent to enter mux mode
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   789
			iTest.Printf(_L("Verify AT+CMUX is sent to enter Mux mode...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   790
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   791
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   792
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   793
			Verify0710Compliance();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   794
			iTest.Printf(_L("Test 6-1 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   795
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   796
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   797
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   798
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   799
		case 2:		// Check that frames are created correctly
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   800
			iTest.Printf(_L("Verify frames are created properly...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   801
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   802
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   803
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   804
			Verify0710Compliance();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   805
			iTest.Printf(_L("Test 6-2 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   806
			User::After(2000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   807
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   808
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   809
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   810
		case 3:		// Check that channels are created via SABM frames
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   811
			iTest.Printf(_L("Verify channels are created via SABM frames...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   812
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   813
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   814
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   815
			Verify0710Compliance();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   816
			iTest.Printf(_L("Test 6-3 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   817
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   818
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   819
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   820
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   821
		case 4:		// Check that received frames are validated
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   822
			iTest.Printf(_L("Verify received frames are validated...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   823
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   824
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   825
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   826
			Verify0710Compliance();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   827
			iTest.Printf(_L("Test 6-4 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   828
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   829
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   830
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   831
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   832
		case 5:		// Check that recv frames are ack'd with a UA frame
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   833
			iTest.Printf(_L("Verify received frames are ack'd with a UA frame...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   834
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   835
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   836
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   837
			Verify0710Compliance();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   838
			iTest.Printf(_L("Test 6-5 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   839
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   840
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   841
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   842
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   843
		case 6:		// Check that received modem status control frames are processed correctly
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   844
			iTest.Printf(_L("Verify received modem status control frames are processed...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   845
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   846
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   847
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   848
			Verify0710Compliance();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   849
			iTest.Printf(_L("Test 6-6 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   850
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   851
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   852
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   853
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   854
		case 7:		// Check that received flow control frames are processed correctly
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   855
			iTest.Printf(_L("Verify received flow control frames are processed...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   856
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   857
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   858
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   859
			Verify0710Compliance();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   860
			iTest.Printf(_L("Test 6-7 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   861
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   862
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   863
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   864
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   865
		case 8:		// Check that channel is closed by sending a DISC frame
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   866
			iTest.Printf(_L("Verify channel is closed by when sending DISC frame...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   867
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   868
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   869
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   870
			Verify0710Compliance();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   871
			iTest.Printf(_L("Test 6-8 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   872
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   873
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   874
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   875
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   876
			// Manual Tests Follow...
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   877
		case 100:		// Return how many manual tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   878
			return 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   879
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   880
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   881
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   882
			iTest.Printf(_L("** Not implemented CSYF-%d **\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   883
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   884
		}			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   885
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   886
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   887
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   888
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   889
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   890
TInt CCsy0710UnitTest::CsyGL(TInt aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   891
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   892
 * CSY Tests
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   893
 * @param aTstNum test number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   894
 * @return KErrNone or error code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   895
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   896
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   897
	if (aTstNum != 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   898
		iTest.Printf(_L("CSYG-%d\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   899
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   900
	SetTsIdentifier(_L("CSYG"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   901
	SetMethodName(_L("CSYG"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   902
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   903
	switch (aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   904
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   905
		case 0:		// Return how may auto tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   906
			return (14);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   907
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   908
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   909
		case 1:		// Verify no memory allocation until 1st port is opened
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   910
			iTest.Printf(_L("Verify no memory allocation until 1st port is opened...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   911
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   912
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   913
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   914
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   915
			iTest.Printf(_L("Test 7-1 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   916
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   917
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   918
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   919
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   920
		case 2:		// Verify mux startup params are read
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   921
			iTest.Printf(_L("Verify mux startup params are read...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   922
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   923
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   924
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   925
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   926
			iTest.Printf(_L("Test 7-2 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   927
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   928
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   929
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   930
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   931
		case 3:		// Verify correct serial port PDD is loaded
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   932
			iTest.Printf(_L("Verify correct serial port PDD is loaded...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   933
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   934
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   935
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   936
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   937
			iTest.Printf(_L("Test 7-3 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   938
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   939
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   940
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   941
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   942
		case 4:		// Verify correct serial port LDD is loaded
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   943
			iTest.Printf(_L("Verify correct serial port LDD is loaded...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   944
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   945
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   946
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   947
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   948
			iTest.Printf(_L("Test 7-4 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   949
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   950
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   951
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   952
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   953
		case 5:		// Check serial port startup config
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   954
			iTest.Printf(_L("Verify serial port startup config...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   955
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   956
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   957
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   958
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   959
			iTest.Printf(_L("Test 7-5 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   960
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   961
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   962
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   963
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   964
		case 6:		// Check control channel 0 is created
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   965
			iTest.Printf(_L("Verify control channel 0 is created...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   966
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   967
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   968
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   969
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   970
			iTest.Printf(_L("Test 7-6 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   971
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   972
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   973
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   974
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   975
		case 7:		// Check command and data channels are created
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   976
			iTest.Printf(_L("Verify cmd and data channels are created...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   977
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   978
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   979
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   980
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   981
			iTest.Printf(_L("Test 7-7 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   982
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   983
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   984
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   985
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   986
		case 8:		// Verify enter mux AT command is issued to the BP
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   987
			iTest.Printf(_L("Verify enter mux AT command is issued to BP...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   988
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   989
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   990
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   991
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   992
			iTest.Printf(_L("Test 7-8 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   993
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   994
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   995
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   996
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   997
		case 9:		// Verify cmd channels are setup disable cmd echo
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   998
			iTest.Printf(_L("Verify cmd channels are setup to disable cmd echo...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   999
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1000
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1001
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1002
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1003
			iTest.Printf(_L("Test 7-9 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1004
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1005
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1006
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1007
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1008
		case 10:	// Verify C32 is informed of the CSY's serial name of "gsm0710"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1009
			iTest.Printf(_L("Verify C32 is informed of the CSY's serial name of gsm0710...\n"));	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1010
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1011
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1012
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1013
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1014
			iTest.Printf(_L("Test 7-10 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1015
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1016
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1017
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1018
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1019
		case 11:	// Verify flow control is set to Off after channel init
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1020
			iTest.Printf(_L("Verify Verify flow control is set to Off after channel init...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1021
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1022
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1023
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1024
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1025
			iTest.Printf(_L("Test 7-11 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1026
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1027
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1028
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1029
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1030
		case 12:	// Verify NotifyFlowControlChange requests are accepted
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1031
			iTest.Printf(_L("Verify NotifyFlowControlChange requests are accepted...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1032
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1033
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1034
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1035
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1036
			iTest.Printf(_L("Test 7-12 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1037
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1038
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1039
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1040
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1041
		case 13:	// Verify NotifyFlowControlChange request can be cancelled
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1042
			iTest.Printf(_L("Verify NotifyFlowControlChange request can be cancelled...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1043
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1044
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1045
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1046
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1047
			iTest.Printf(_L("Test 7-13 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1048
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1049
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1050
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1051
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1052
		case 14:	// Verify NotifyFlowControlChange requests are completed properly
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1053
			iTest.Printf(_L("Verify NotifyFlowControlChange requests are completed properly...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1054
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1055
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1056
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1057
			VerifyStartup();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1058
			iTest.Printf(_L("Test 7-14 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1059
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1060
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1061
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1062
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1063
			// Manual Tests Follow...
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1064
		case 100:		// Return how many manual tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1065
			return 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1066
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1067
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1068
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1069
			iTest.Printf(_L("** Not implemented CSYG-%d **\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1070
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1071
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1072
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1073
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1074
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1075
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1076
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1077
TInt CCsy0710UnitTest::CsyHL(TInt aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1078
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1079
 * CSY Tests
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1080
 * @param aTstNum test number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1081
 * @return KErrNone or error code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1082
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1083
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1084
	if (aTstNum != 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1085
		iTest.Printf(_L("CSYH-%d\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1086
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1087
	SetTsIdentifier(_L("CSYH"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1088
	SetMethodName(_L("CSYH"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1089
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1090
	switch (aTstNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1091
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1092
		case 0:		// Return how may auto tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1093
			return (5);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1094
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1095
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1096
		case 1:		// Verify any active or outstanding requests are cancelled
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1097
			iTest.Printf(_L("Verify any active or outstanding requests are cancelled...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1098
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1099
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1100
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1101
			TEST(VerifyShutdown(1));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1102
			iTest.Printf(_L("Test 8-1 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1103
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1104
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1105
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1106
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1107
		case 2:		// Verify each command channel and control channel is disconnected by sending DISC frame to BP
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1108
			iTest.Printf(_L("Verify channels are disconnected by sending DISC frame to BP...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1109
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1110
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1111
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1112
			TEST(VerifyShutdown(2));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1113
			iTest.Printf(_L("Test 8-2 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1114
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1115
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1116
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1117
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1118
		case 3:		// Verify all memory allocated is deallocated
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1119
			iTest.Printf(_L("Verify all memory allocated is deallocated...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1120
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1121
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1122
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1123
			TEST(VerifyShutdown(3));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1124
			iTest.Printf(_L("Test 8-3 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1125
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1126
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1127
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1128
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1129
		case 4:		// Verify all created objects are deleted
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1130
			iTest.Printf(_L("Verify all created objects are deleted...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1131
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1132
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1133
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1134
			TEST(VerifyShutdown(4));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1135
			iTest.Printf(_L("Test 8-4 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1136
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1137
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1138
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1139
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1140
		case 5:		// Verify BP is returned to non-mux mode for AT commands.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1141
			iTest.Printf(_L("Verify BP is returned to non-mux mode for AT commands....\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1142
			SetFunIndex(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1143
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1144
			// common test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1145
			TEST(VerifyShutdown(5));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1146
			iTest.Printf(_L("Test 8-5 Passed\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1147
			User::After(3000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1148
			return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1149
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1150
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1151
			// Manual Tests Follow...
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1152
		case 100:		// Return how many manual tests are present
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1153
			return 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1154
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1155
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1156
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1157
			iTest.Printf(_L("** Not implemented CSYH-%d **\n"), aTstNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1158
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1159
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1160
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1161
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1162
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1163
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1164
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1165
////////////////////
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1166
// Helper classes
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1167
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1168
TInt CCsy0710UnitTest::LoadSerialDeviceDrivers()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1169
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1170
#ifdef __WINS__
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1171
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1172
	_LIT(KPDDName,"ECDRV");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1173
	_LIT(KLDDName,"ECOMM");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1174
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1175
	ret= User::LoadPhysicalDevice(KPDDName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1176
	if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1177
		return (ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1178
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1179
	ret = User::LoadLogicalDevice(KLDDName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1180
	if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1181
		return (ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1182
#endif
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1183
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1184
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1185
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1186
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1187
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1188
TInt CCsy0710UnitTest::OpenAllCommPorts()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1189
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1190
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1191
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1192
	// Open RComm Ports
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1193
	ret = iCommPort[0].Open(iCommServer, iCmdPortName[0], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1194
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1195
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1196
	// Open Port #2
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1197
	ret = iCommPort[1].Open(iCommServer, iCmdPortName[1], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1198
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1199
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1200
	// Open Port #3
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1201
	ret = iCommPort[2].Open(iCommServer, iCmdPortName[2], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1202
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1203
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1204
	// Open Port #4
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1205
	ret = iCommPort[3].Open(iCommServer, iCmdPortName[3], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1206
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1207
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1208
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1209
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1210
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1211
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1212
TInt CCsy0710UnitTest::CloseAllCommPorts()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1213
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1214
	iCommPort[0].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1215
	iCommPort[1].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1216
	iCommPort[2].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1217
	iCommPort[3].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1218
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1219
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1220
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1221
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1222
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1223
TInt CCsy0710UnitTest::GetCsyInfo()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1224
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1225
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1226
	TName csyName(_L("gsm0710"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1227
	TSerialInfo serialInfo;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1228
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1229
	ret = iCommServer.GetPortInfo(csyName, serialInfo);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1230
	if (ret == KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1231
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1232
		iTest.Printf(_L("    Descrip   = %S\n"), &serialInfo.iDescription);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1233
		iTest.Printf(_L("    Name      = %S\n"), &serialInfo.iName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1234
		iTest.Printf(_L("    Low Unit  = %d\n"), serialInfo.iLowUnit);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1235
		iTest.Printf(_L("    High Unit = %d\n"), serialInfo.iHighUnit);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1236
		User::After(2000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1237
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1238
	return (ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1239
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1240
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1241
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1242
TInt CCsy0710UnitTest::OpenCommPortFail()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1243
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1244
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1245
	TName invalidName = _L("gsm0710::A");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1246
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1247
	ret = iCommPort[0].Open(iCommServer, invalidName, ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1248
	if (ret == KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1249
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1250
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1251
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1252
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1253
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1254
TInt CCsy0710UnitTest::OpenCmdPortTwice()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1255
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1256
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1257
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1258
	// Open RComm Port once
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1259
	ret = iCommPort[0].Open(iCommServer, iCmdPortName[0], ECommExclusive);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1260
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1261
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1262
	// Open same RComm Port again
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1263
	ret = iCommPort[1].Open(iCommServer, iCmdPortName[0], ECommExclusive);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1264
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1265
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1266
	iCommPort[0].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1267
	iCommPort[1].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1268
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1269
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1270
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1271
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1272
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1273
TInt CCsy0710UnitTest::OpenCmdPortInvalidName()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1274
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1275
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1276
	TName invalidName = _L("gsm0710::A");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1277
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1278
	ret = iCommPort[0].Open(iCommServer, invalidName, ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1279
	if (ret == KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1280
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1281
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1282
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1283
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1284
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1285
TInt CCsy0710UnitTest::SendCmdOneCommPort(TInt aPortNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1286
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1287
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1288
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1289
	// Open RComm Port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1290
	ret = iCommPort[aPortNum].Open(iCommServer, iCmdPortName[aPortNum], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1291
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1292
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1293
	// send data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1294
	TBuf8<32> buf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1295
	buf.Copy(KATCommand1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1296
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1297
	TRequestStatus writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1298
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1299
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1300
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1301
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1302
	TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1303
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1304
	iCommPort[aPortNum].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1305
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1306
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1307
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1308
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1309
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1310
TInt CCsy0710UnitTest::SendCmdsOneCommPort(TInt aPortNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1311
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1312
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1313
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1314
	// Open RComm Port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1315
	ret = iCommPort[aPortNum].Open(iCommServer, iCmdPortName[aPortNum], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1316
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1317
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1318
	TRequestStatus writeRequestStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1319
	TBuf8<32> buf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1320
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1321
	// send data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1322
	writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1323
	buf.Copy(KATCommand1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1324
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1325
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1326
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1327
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1328
	TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1329
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1330
	writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1331
	buf.Copy(KATCommand2);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1332
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1333
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1334
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1335
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1336
	TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1337
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1338
	writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1339
	buf.Copy(KATCommand3);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1340
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1341
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1342
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1343
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1344
	TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1345
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1346
	writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1347
	buf.Copy(KATCommand4);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1348
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1349
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1350
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1351
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1352
	TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1353
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1354
	writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1355
	buf.Copy(KATCommand5);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1356
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1357
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1358
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1359
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1360
	TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1361
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1362
	writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1363
	buf.Copy(KATCommand6);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1364
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1365
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1366
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1367
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1368
	TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1369
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1370
	writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1371
	buf.Copy(KATCommand7);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1372
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1373
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1374
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1375
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1376
	TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1377
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1378
	writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1379
	buf.Copy(KATCommand8);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1380
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1381
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1382
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1383
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1384
	TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1385
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1386
	iCommPort[aPortNum].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1387
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1388
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1389
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1390
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1391
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1392
TInt CCsy0710UnitTest::CancelWriteOneCommPort(TInt aPortNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1393
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1394
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1395
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1396
	// Open RComm Port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1397
	ret = iCommPort[aPortNum].Open(iCommServer, iCmdPortName[aPortNum], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1398
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1399
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1400
	// wait for CSY to initialize
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1401
	// check current flow control state
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1402
	TFlowControl flow;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1403
	iCommPort[aPortNum].GetFlowControlStatus(flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1404
	if (flow == EFlowControlOn)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1405
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1406
		// Port isn't active yet - wait for it to become active
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1407
		//gTest.Printf(_L("Waiting for port 1 to become active...\n\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1408
		TRequestStatus flowReqStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1409
		iCommPort[aPortNum].NotifyFlowControlChange(flowReqStatus, flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1410
		User::WaitForRequest(flowReqStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1411
		if (flow == EFlowControlOn)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1412
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1413
			iTest.Printf(_L("Incorrect flow %d\n"), flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1414
			iTest.Printf(_L("*** CSY did not init properly!! ***\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1415
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1416
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1417
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1418
	User::After(5000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1419
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1420
	TRequestStatus writeRequestStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1421
	TBuf8<100> buf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1422
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1423
	// send data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1424
	writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1425
	buf.Copy(KATCommandToCancel);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1426
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1427
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1428
	// cancel write request
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1429
 	iCommPort[aPortNum].WriteCancel();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1430
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1431
	if (writeRequestStatus != KErrCancel && writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1432
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1433
	if (writeRequestStatus == KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1434
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1435
		TEST(ReadDataFromCommPort(aPortNum));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1436
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1437
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1438
	iCommPort[aPortNum].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1439
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1440
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1441
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1442
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1443
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1444
TInt CCsy0710UnitTest::RecvDataOneCommPort(TInt aPortNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1445
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1446
	iTest.Printf(_L("  Port %d\n"), aPortNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1447
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1448
	// wait for CSY to initialize
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1449
	// check current flow control state
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1450
	TFlowControl flow;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1451
	iCommPort[aPortNum].GetFlowControlStatus(flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1452
	if (flow == EFlowControlOn)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1453
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1454
		// Port isn't active yet - wait for it to become active
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1455
		TRequestStatus flowReqStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1456
		iCommPort[aPortNum].NotifyFlowControlChange(flowReqStatus, flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1457
		User::WaitForRequest(flowReqStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1458
		if (flow == EFlowControlOn) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1459
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1460
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1461
	User::After(5000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1462
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1463
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1464
	// send data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1465
	TBuf8<32> buf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1466
	buf.Copy(KATCommand1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1467
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1468
	TRequestStatus writeRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1469
 	iCommPort[aPortNum].Write(writeRequestStatus, buf, buf.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1470
	User::WaitForRequest(writeRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1471
	if (writeRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1472
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1473
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1474
	// Recv Data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1475
	TRequestStatus readRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1476
	TBuf8<80> respBuf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1477
	// gTest.Printf(_L("Port 1 Read ...\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1478
 	iCommPort[aPortNum].ReadOneOrMore(readRequestStatus,respBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1479
	User::WaitForRequest(readRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1480
	if (readRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1481
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1482
	User::After(100000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1483
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1484
	// see if there is any more data to read
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1485
 	TInt extraRecvData = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1486
	while ((extraRecvData = iCommPort[aPortNum].QueryReceiveBuffer()) > 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1487
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1488
		respBuf.Zero();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1489
		readRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1490
 		iCommPort[aPortNum].ReadOneOrMore(readRequestStatus, respBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1491
 		//iCommPort[aPortNum].Read(readRequestStatus, respBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1492
		User::WaitForRequest(readRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1493
		if (readRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1494
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1495
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1496
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1497
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1498
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1499
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1500
TInt CCsy0710UnitTest::ReadDataFromCommPort(TInt aPortNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1501
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1502
	// Recv Data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1503
	TRequestStatus readRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1504
	TBuf8<80> respBuf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1505
 	iCommPort[aPortNum].ReadOneOrMore(readRequestStatus, respBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1506
	User::WaitForRequest(readRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1507
	if (readRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1508
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1509
	User::After(100000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1510
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1511
	// see if there is any more data to read
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1512
 	TInt extraRecvData = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1513
	while ((extraRecvData = iCommPort[aPortNum].QueryReceiveBuffer()) > 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1514
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1515
		respBuf.Zero();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1516
		readRequestStatus = KRequestPending;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1517
 		iCommPort[aPortNum].ReadOneOrMore(readRequestStatus, respBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1518
		User::WaitForRequest(readRequestStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1519
		if (readRequestStatus != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1520
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1521
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1522
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1523
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1524
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1525
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1526
TInt CCsy0710UnitTest::VerifyFlowControl(TInt aPortNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1527
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1528
	iTest.Printf(_L("  Port %d\n"), aPortNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1529
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1530
	// check current flow control state
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1531
	TFlowControl flow;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1532
	iCommPort[aPortNum].GetFlowControlStatus(flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1533
	if (flow == EFlowControlOn)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1534
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1535
		// Port isn't active yet - wait for it to become active
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1536
		TRequestStatus flowReqStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1537
		iCommPort[aPortNum].NotifyFlowControlChange(flowReqStatus, flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1538
		User::WaitForRequest(flowReqStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1539
		if (flow == EFlowControlOn)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1540
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1541
			iTest.Printf(_L("Incorrect flow %d\n"), flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1542
			iTest.Printf(_L("*** CSY did not init properly!! ***\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1543
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1544
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1545
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1546
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1547
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1548
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1549
TInt CCsy0710UnitTest::Verify0710Compliance()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1550
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1551
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1552
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1553
	TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1554
    ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1555
    if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1556
       TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1557
	TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1558
	ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1559
	if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1560
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1561
	// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1562
	ret = iCommPort[0].Open(iCommServer, iCmdPortName[0], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1563
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1564
	ret = iCommPort[1].Open(iCommServer, iCmdPortName[1], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1565
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1566
	ret = iCommPort[2].Open(iCommServer, iCmdPortName[2], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1567
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1568
	ret = iCommPort[3].Open(iCommServer, iCmdPortName[3], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1569
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1570
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1571
	TEST(VerifyFlowControl(0));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1572
	TEST(VerifyFlowControl(1));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1573
	TEST(VerifyFlowControl(2));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1574
	TEST(VerifyFlowControl(3));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1575
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1576
	iCommPort[3].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1577
	iCommPort[2].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1578
	iCommPort[1].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1579
	iCommPort[0].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1580
	User::After(1000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1581
	iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1582
	iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1583
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1584
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1585
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1586
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1587
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1588
TInt CCsy0710UnitTest::VerifyStartup()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1589
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1590
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1591
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1592
	TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1593
    ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1594
    if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1595
        TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1596
	TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1597
	ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1598
	if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1599
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1600
	// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1601
	ret = iCommPort[0].Open(iCommServer, iCmdPortName[0], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1602
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1603
	ret = iCommPort[1].Open(iCommServer, iCmdPortName[1], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1604
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1605
	ret = iCommPort[2].Open(iCommServer, iCmdPortName[2], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1606
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1607
	ret = iCommPort[3].Open(iCommServer, iCmdPortName[3], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1608
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1609
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1610
	TEST(VerifyStartupFlowControl(0));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1611
	TEST(VerifyStartupFlowControl(1));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1612
	TEST(VerifyStartupFlowControl(2));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1613
	TEST(VerifyStartupFlowControl(3));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1614
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1615
	iCommPort[3].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1616
	iCommPort[2].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1617
	iCommPort[1].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1618
	iCommPort[0].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1619
	User::After(1000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1620
	iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1621
	iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1622
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1623
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1624
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1625
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1626
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1627
TInt CCsy0710UnitTest::VerifyStartupFlowControl(TInt aPortNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1628
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1629
	// check current flow control state
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1630
	TFlowControl flow;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1631
	iCommPort[aPortNum].GetFlowControlStatus(flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1632
	if (flow == EFlowControlOn)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1633
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1634
		// Port isn't active yet - wait for it to become active
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1635
		TRequestStatus flowReqStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1636
		iCommPort[aPortNum].NotifyFlowControlChange(flowReqStatus, flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1637
		User::WaitForRequest(flowReqStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1638
		if (flow == EFlowControlOn)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1639
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1640
			iTest.Printf(_L("Incorrect flow %d\n"), flow);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1641
			iTest.Printf(_L("*** CSY did not init properly!! ***\n"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1642
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1643
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1644
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1645
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1646
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1647
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1648
TInt CCsy0710UnitTest::VerifyShutdown(TInt aTestSubset)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1649
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1650
	aTestSubset = aTestSubset;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1651
	TInt ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1652
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1653
	TEST(LoadSerialDeviceDrivers());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1654
    ret = StartC32();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1655
    if ((ret != KErrNone) && (ret != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1656
        TEST(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1657
	TEST(iCommServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1658
	ret = iCommServer.LoadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1659
	if (ret!=KErrNone && ret!=KErrAlreadyExists) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1660
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1661
	// specific test code
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1662
	ret = iCommPort[0].Open(iCommServer, iCmdPortName[0], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1663
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1664
	ret = iCommPort[1].Open(iCommServer, iCmdPortName[1], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1665
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1666
	ret = iCommPort[2].Open(iCommServer, iCmdPortName[2], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1667
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1668
	ret = iCommPort[3].Open(iCommServer, iCmdPortName[3], ECommShared);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1669
	if (ret != KErrNone) return __LINE__;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1670
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1671
	TEST(VerifyStartupFlowControl(0));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1672
	TEST(VerifyStartupFlowControl(1));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1673
	TEST(VerifyStartupFlowControl(2));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1674
	TEST(VerifyStartupFlowControl(3));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1675
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1676
	iCommPort[3].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1677
	iCommPort[2].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1678
	iCommPort[1].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1679
	iCommPort[0].Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1680
	User::After(1000000);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1681
	iCommServer.UnloadCommModule(KCsyName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1682
	iCommServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1683
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1684
	return (KErrNone);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1685
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1686
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1687
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1688
/////////////////////////////////////////////////
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1689
//The following functions also need to be implemented by
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1690
//CUnitTestBase derived classes 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1691
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1692
void CCsy0710UnitTest::CreateTestL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1693
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1694
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1695
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1696
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1697
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1698
	CCsy0710UnitTest* unitTest=CCsy0710UnitTest::NewL(
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1699
		KCsy0710UnitTest, KCsy0710UnitTestLog, KUnitTestSpec, KCsy0710UnitTestScript);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1700
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1701
	CleanupStack::PushL(unitTest);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1702
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1703
	TInt ret=unitTest->SetUpTest();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1704
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1705
	if(!ret)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1706
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1707
		unitTest->RunUnitTestsL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1708
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1709
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1710
	unitTest->Test().End();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1711
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1712
	CleanupStack::PopAndDestroy(1); //unitTest
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1713
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1714
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1715
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1716
#ifndef _ACCEPTANCE_TESTS
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1717
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1718
GLDEF_C TInt E32Main()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1719
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1720
// Main entry point - make sure everything is going.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1721
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1722
#ifdef BUILD_FOR_JETSTREAM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1723
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1724
	RProcess().SecureApi(RProcess::ESecureApiOn);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1725
	RProcess().DataCaging(RProcess::EDataCagingOn);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1726
	// We must include the brace in the #ifndef to allow the security
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1727
	// checking script 'perl.txt' to pass.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1728
#else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1729
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1730
#endif // BUILD_FOR_JETSTREAM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1731
	CTrapCleanup* cleanup=CTrapCleanup::New(); // get clean-up stack
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1732
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1733
	TRAPD(ret,CCsy0710UnitTest::CreateTestL());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1734
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1735
	delete cleanup;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1736
	return KErrNone;        
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1737
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1738
8b72faa1200f 201024_02
hgs
parents:
diff changeset
  1739
#endif //_ACCEPTANCE_TESTS