applayerprotocols/httptransportfw/Test/T_WspDecoder/WspHeaderReaderUnitTestContext.inl
changeset 0 b16258d2340f
equal deleted inserted replaced
-1:000000000000 0:b16258d2340f
       
     1 // Copyright (c) 2001-2009 Nokia Corporation and/or its subsidiary(-ies).
       
     2 // All rights reserved.
       
     3 // This component and the accompanying materials are made available
       
     4 // under the terms of "Eclipse Public License v1.0"
       
     5 // which accompanies this distribution, and is available
       
     6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     7 //
       
     8 // Initial Contributors:
       
     9 // Nokia Corporation - initial contribution.
       
    10 //
       
    11 // Contributors:
       
    12 //
       
    13 // Description:
       
    14 // The context for the unit tests upon the CWspHeaderReader class methods.
       
    15 // 
       
    16 //
       
    17 
       
    18 /**
       
    19  @file WspHeaderReaderUnitTestContext.inl
       
    20 */
       
    21 
       
    22 // User includes
       
    23 #include "WspHeaderReaderTransitions.h"
       
    24 #include "cheaders.h"
       
    25 #include "cheaderfield.h"
       
    26 
       
    27 // System includes
       
    28 #include <wspstringconstants.h>
       
    29 
       
    30 _LIT8(KTxtTestHeader, "TestHeader");
       
    31 
       
    32 // ______________________________________________________________________________
       
    33 //
       
    34 inline CWspHeaderReader_UnitTestContext::CWspHeaderReader_UnitTestContext(CDataLogger& aDataLogger,
       
    35 												MStateAccessor& aStateAccessor,
       
    36 												MTransitionObserver& aObserver,
       
    37 												const TStringTable& aStrTable)
       
    38 : CUnitTestContext(aDataLogger, aStateAccessor, aObserver), iStrTable(aStrTable)
       
    39 	{
       
    40 	//Do nothing
       
    41 	}
       
    42 
       
    43 inline CWspHeaderReader_UnitTestContext::~CWspHeaderReader_UnitTestContext()
       
    44 	{
       
    45 	delete iExpectedData;
       
    46 	delete iOutputData;
       
    47 	delete iTestHeader;
       
    48 	delete iHeaderField;
       
    49 	delete iHeader;
       
    50 	delete iCodec;
       
    51 	iStrPool.Close();
       
    52 	}
       
    53 
       
    54 inline void CWspHeaderReader_UnitTestContext::ConstructL(TInt aHeaderName)
       
    55 	{
       
    56 	iHeaderToken = aHeaderName;
       
    57 	iStrPool.OpenL(iStrTable);
       
    58 	iCodec = CWspHeaderCodec::NewL(iStrPool, iStrTable);
       
    59 	REINTERPRET_CAST(CWspHeaderCodec*, iCodec)->SetWspVersion(CWspHeaderCodec::EVersion1_4);
       
    60 	iHeader = CHeaders::NewL(*iCodec);
       
    61 	if( iHeaderToken == KErrNotFound )
       
    62 		{
       
    63 		RStringF testHeader = iStrPool.OpenFStringL(KTxtTestHeader());
       
    64 		CleanupClosePushL(testHeader);
       
    65 		iHeaderField = CHeaderField::NewL(testHeader, *iHeader);
       
    66 		CleanupStack::PopAndDestroy(&testHeader);
       
    67 		}
       
    68 	else
       
    69 		{
       
    70 		iHeaderField = CHeaderField::NewL(iStrPool.StringF(aHeaderName, iStrTable), *iHeader);
       
    71 		}
       
    72 	iTestHeader = new(ELeave) RHeaderField(*iHeaderField);
       
    73 	}
       
    74 
       
    75 inline void CWspHeaderReader_UnitTestContext::SetOutputL()
       
    76 	{
       
    77 	_LIT8(KPartSeparator, ",");
       
    78 	_LIT8(KParamSeparator, ";");
       
    79 	_LIT8(KParamValueSeparator, "=");
       
    80 	// "Sun, 06 Nov 1994 08:49:37 GMT"  ; RFC 822, updated by RFC 1123
       
    81 	_LIT(KDateFormatRfc1123,"%*E,%D%*N%Y %1 %2 %3 %H:%T:%S GMT");
       
    82 
       
    83 	TBuf8<512> data;
       
    84 	THeaderFieldPartIter iter  = iTestHeader->PartsL();
       
    85 	iter.First();
       
    86 	TInt partCount = 0;
       
    87 	while( !(iter.AtEnd()) )
       
    88 		{
       
    89 		if( partCount > 0 )
       
    90 			data.Append(KPartSeparator);
       
    91 
       
    92 		const CHeaderFieldPart* fieldPart = iter();
       
    93 		THTTPHdrVal hdrVal = fieldPart->Value();
       
    94 		switch( hdrVal.Type() )
       
    95 			{
       
    96 			case THTTPHdrVal::KStrFVal:
       
    97 				{
       
    98 				data.Append(hdrVal.StrF().DesC());
       
    99 				} break;
       
   100 			case THTTPHdrVal::KStrVal:
       
   101 				{
       
   102 				data.Append(hdrVal.Str().DesC());
       
   103 				} break;
       
   104 			case THTTPHdrVal::KTIntVal:
       
   105 				{
       
   106 				TBuf8<25> convertNum;
       
   107 				convertNum.Num(hdrVal.Int());
       
   108 				data.Append(convertNum);
       
   109 				} break;
       
   110 			case THTTPHdrVal::KDateVal:
       
   111 				{
       
   112 				// Formate the date string in GMT
       
   113 				TBuf<40> dateTimeStringRfc1123;
       
   114 				TTime t(hdrVal.DateTime());
       
   115 				t.FormatL(dateTimeStringRfc1123,KDateFormatRfc1123);
       
   116 				// convert from unicode
       
   117 				TBuf8<40> dateTimeString8;
       
   118 				dateTimeString8.Copy(dateTimeStringRfc1123);
       
   119 				data.Append(dateTimeString8);
       
   120 				} break;
       
   121 			default:
       
   122 				break;
       
   123 			}
       
   124 		++iter;
       
   125 		++partCount;
       
   126 
       
   127 		// Check how many parameters there are on this part
       
   128 		TInt numParams = fieldPart->NumParameters();
       
   129 		// loop through all the paramters and them to the descriptor
       
   130 		for( TInt i=0; i<numParams; ++i )
       
   131 			{
       
   132 			data.Append(KParamSeparator);
       
   133 			CHeaderFieldParam* fieldParam = fieldPart->Parameter(i);
       
   134 			data.Append(fieldParam->Name().DesC());
       
   135 			if(fieldParam->Value().Type() == THTTPHdrVal::KStrFVal)
       
   136 				{
       
   137 				if(fieldParam->Value().StrF().DesC().Length()!=0)
       
   138 					data.Append(KParamValueSeparator);
       
   139 				}
       
   140 			else
       
   141 				data.Append(KParamValueSeparator);
       
   142 
       
   143 			THTTPHdrVal paramVal = fieldParam->Value();
       
   144 			switch( paramVal.Type() )
       
   145 				{
       
   146 				case THTTPHdrVal::KStrFVal:
       
   147 					{
       
   148 					data.Append(paramVal.StrF().DesC());
       
   149 					} break;
       
   150 				case THTTPHdrVal::KStrVal:
       
   151 					{
       
   152 					data.Append(paramVal.Str().DesC());
       
   153 					} break;
       
   154 				case THTTPHdrVal::KTIntVal:
       
   155 					{
       
   156 					TBuf8<25> convertNum;
       
   157 					convertNum.Num(paramVal.Int());
       
   158 					data.Append(convertNum);
       
   159 					} break;
       
   160 				case THTTPHdrVal::KDateVal:
       
   161 					{
       
   162 					// Formate the date string in GMT
       
   163 					TBuf<40> dateTimeStringRfc1123;
       
   164 					TTime t(paramVal.DateTime());
       
   165 					t.FormatL(dateTimeStringRfc1123,KDateFormatRfc1123);
       
   166 					// convert from unicode
       
   167 					TBuf8<40> dateTimeString8;
       
   168 					dateTimeString8.Copy(dateTimeStringRfc1123);
       
   169 					data.Append(dateTimeString8);
       
   170 					} break;
       
   171 				default:
       
   172 					break;
       
   173 				}
       
   174 			}
       
   175 		}
       
   176 
       
   177 	// We have the data converted to text form so now add to the context
       
   178 	iOutputData = data.AllocL();
       
   179 	}
       
   180 
       
   181 inline void CWspHeaderReader_UnitTestContext::SetExpectedL(const TDesC8& aExpectedData)
       
   182 	{
       
   183 	iExpectedData = aExpectedData.AllocL();
       
   184 	}
       
   185 
       
   186 inline void CWspHeaderReader_UnitTestContext::SetTrapOutputL()
       
   187 	{
       
   188 	CHeaderField* headerField = CHeaderField::NewL(iStrPool.StringF(iHeaderToken, iStrTable), *iHeader);
       
   189 	CleanupStack::PushL(headerField);
       
   190 	RHeaderField testHeader(*headerField);
       
   191 	testHeader.BeginRawDataL();
       
   192 	TPtrC8 rawData;
       
   193 	iTestHeader->RawDataL(rawData);
       
   194 	testHeader.WriteRawDataL(rawData);
       
   195 	testHeader.CommitRawData();
       
   196 	TRAPD(err, testHeader.PartsL());
       
   197 	CleanupStack::PopAndDestroy(headerField);
       
   198 	TBuf8<25> convertNum;
       
   199 	convertNum.Num(err);
       
   200 	iOutputData = convertNum.AllocL();
       
   201 	}