--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/genericservices/httputils/Test/t_wspcodec/cwspencodetest.cpp Tue Feb 02 02:01:42 2010 +0200
@@ -0,0 +1,407 @@
+// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// Implementation of test CWSPEncodeTest.
+//
+//
+
+
+#include "cwspencodetest.h"
+#include <wspencoder.h>
+
+
+CWSPEncodeTest* CWSPEncodeTest::NewLC(CIpuTestHarness* aTestHarness)
+ {
+ CWSPEncodeTest* self = new(ELeave)CWSPEncodeTest(aTestHarness);
+ CleanupStack::PushL(self);
+ return self;
+ }
+
+
+CWSPEncodeTest::CWSPEncodeTest(CIpuTestHarness* aTestHarness):
+ iTestHarness(aTestHarness)
+ {}
+
+CWSPEncodeTest::~CWSPEncodeTest()
+ {}
+
+void CWSPEncodeTest::DoTestsL()
+ {
+ HeaderEncoderTestL();
+ ShortIntTestL();
+ LongIntTestL();
+ UintVarTestL();
+ StringTestL();
+ DateTestL();
+ }
+
+
+void CWSPEncodeTest::HeaderEncoderTestL()
+ {
+ _LIT(KTestText, "WSP Encode: Header");
+ iTestHarness->StartTestL(KTestText);
+ TRAPD(error, TestHeaderEncoderL());
+ iTestHarness->EndTest(error);
+ User::LeaveIfError(error);
+ }
+
+void CWSPEncodeTest::TestHeaderEncoderL()
+ {
+ TInt err=0;
+
+ CWspHeaderEncoder* primEncoder = CWspHeaderEncoder::NewLC();
+
+ primEncoder->StartHeaderL(0x27);
+ primEncoder->StartValueLengthL();
+ primEncoder->AddUintVarL(0xff);
+ primEncoder->AddLongIntL(999999);
+ primEncoder->AddIntegerL(0x7F);
+ primEncoder->EndValueLengthL();
+ HBufC8* buf = primEncoder->EndHeaderL();
+ CleanupStack::PushL(buf);
+ CleanupStack::PopAndDestroy(2); //primEncoder, buf
+
+ User::LeaveIfError(err);
+ }
+
+
+void CWSPEncodeTest::ShortIntTestL()
+ {
+ _LIT(KTestText, "WSP Encode: ShortInt");
+ iTestHarness->StartTestL(KTestText);
+ TInt error = TestShortInt();
+ iTestHarness->EndTest(error);
+ User::LeaveIfError(error);
+ }
+
+
+TInt CWSPEncodeTest::TestShortInt()
+ {
+ TUint8 input;
+ TUint8 output;
+
+ // TWspPrimitiveEncoder::ShortInt
+ // Check 7 and 8 bit values. If 8bit notinh happens
+ input=0; // MIN input value
+ output = TWspPrimitiveEncoder::ShortInt(input);
+ if (output !=128)
+ return KErrGeneral;
+
+ input=35; // MAX input value
+ output = TWspPrimitiveEncoder::ShortInt(input);
+ if (output !=163)
+ return KErrGeneral;
+
+ input=0x7F; // MAX input value
+ output = TWspPrimitiveEncoder::ShortInt(input);
+ if (output !=255)
+ return KErrGeneral;
+
+ input=0x80; // invalid value
+ output = TWspPrimitiveEncoder::ShortInt(input);
+ if (output !=0)
+ return KErrGeneral;
+
+ return KErrNone;
+ }
+
+
+void CWSPEncodeTest::LongIntTestL()
+ {
+ _LIT(KTestText, "WSP Encode: LongInt");
+ iTestHarness->StartTestL(KTestText);
+ TRAPD(error,TestLongIntL());
+ iTestHarness->EndTest(error);
+ User::LeaveIfError(error);
+ }
+
+void CWSPEncodeTest::TestLongIntL()
+ {
+ HBufC8* output=NULL;
+ TBuf8<255> buf;
+ TUint32 input;
+
+ const TUint8 KZeroValueLongInt[] = {0x01, 0x00};
+ const TUint8 K127LongInt[] = {0x01, 0x7F};
+ const TUint8 K255LongInt[] = {0x01, 0xFF};
+ const TUint8 K256LongInt[] = {0x02, 0x01, 0x00};
+ const TUint8 KFFFFLongInt[] = {0x02, 0xFF, 0xFF};
+ const TUint8 K10000LongInt[] = {0x03, 0x01, 0x00, 0x00};
+ const TUint8 KFFFFFFLongInt[] = {0x03, 0xFF, 0xFF, 0xFF};
+ const TUint8 K1000000LongInt[] = {0x04, 0x01, 0x00, 0x00, 0x00};
+ const TUint8 KFFFFFFFFLongInt[] = {0x04, 0xFF, 0xFF, 0xFF, 0xFF};
+
+ input=0;
+ output = TWspPrimitiveEncoder::LongIntL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(KZeroValueLongInt, sizeof(KZeroValueLongInt));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=127;
+ output = TWspPrimitiveEncoder::LongIntL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K127LongInt, sizeof(K127LongInt));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=255;
+ output = TWspPrimitiveEncoder::LongIntL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K255LongInt, sizeof(K255LongInt));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=256;
+ output = TWspPrimitiveEncoder::LongIntL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K256LongInt, sizeof(K256LongInt));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0xFFFF;
+ output = TWspPrimitiveEncoder::LongIntL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(KFFFFLongInt, sizeof(KFFFFLongInt));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0x10000;
+ output = TWspPrimitiveEncoder::LongIntL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K10000LongInt, sizeof(K10000LongInt));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0xFFFFFF;
+ output = TWspPrimitiveEncoder::LongIntL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(KFFFFFFLongInt, sizeof(KFFFFFFLongInt));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0x1000000;
+ output = TWspPrimitiveEncoder::LongIntL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K1000000LongInt, sizeof(K1000000LongInt));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0xFFFFFFFF;
+ output = TWspPrimitiveEncoder::LongIntL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(KFFFFFFFFLongInt, sizeof(KFFFFFFFFLongInt));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+ }
+
+
+void CWSPEncodeTest::UintVarTestL()
+ {
+ _LIT(KTestText, "WSP Encode: UintVar");
+ iTestHarness->StartTestL(KTestText);
+ TRAPD(error,TestUintVarL());
+ iTestHarness->EndTest(error);
+ User::LeaveIfError(error);
+ }
+
+void CWSPEncodeTest::TestUintVarL()
+ {
+
+ HBufC8* output=NULL;
+ TBuf8<255> buf;
+ TUint32 input;
+
+ const TUint8 KMinValue[] = {0x00};
+ const TUint8 KMaxValue[] = {0x8F, 0xFF, 0xFF, 0xFF, 0x7F};
+
+ const TUint8 K7bitBoundaryLower[] = {0x7F};
+ const TUint8 K7bitBoundaryUpper[] = {0x81, 0x00};
+
+ const TUint8 K14bitBoundaryLower[] = {0xFF, 0x7F};
+ const TUint8 K14bitBoundaryUpper[] = {0x81, 0x80, 0x00};
+
+ const TUint8 K21bitBoundaryLower[] = {0xFF, 0xFF, 0x7F};
+ const TUint8 K21bitBoundaryUpper[] = {0x81, 0x80, 0x80, 0x00};
+ const TUint8 K28bitBoundaryLower[] = {0xFF, 0xFF, 0xFF, 0x7F};
+ const TUint8 K28bitBoundaryUpper[] = {0x81, 0x80, 0x80, 0x80, 0x00};
+
+ input=0;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(KMinValue, sizeof(KMinValue));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0xFFFFFFFF;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(KMaxValue, sizeof(KMaxValue));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0x7F;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K7bitBoundaryLower, sizeof(K7bitBoundaryLower));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0x80;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K7bitBoundaryUpper, sizeof(K7bitBoundaryUpper));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0x3FFF;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K14bitBoundaryLower, sizeof(K14bitBoundaryLower));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0x4000;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K14bitBoundaryUpper, sizeof(K14bitBoundaryUpper));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0x1FFFFF;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K21bitBoundaryLower, sizeof(K21bitBoundaryLower));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0x200000;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K21bitBoundaryUpper, sizeof(K21bitBoundaryUpper));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0xFFFFFFF;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K28bitBoundaryLower, sizeof(K28bitBoundaryLower));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ input=0x10000000;
+ output = TWspPrimitiveEncoder::UintVarL(input);
+ CleanupStack::PushL(output);
+ buf.Copy(K28bitBoundaryUpper, sizeof(K28bitBoundaryUpper));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ }
+
+
+void CWSPEncodeTest::StringTestL()
+ {
+ _LIT(KTestText, "WSP Encode: String");
+ iTestHarness->StartTestL(KTestText);
+ TRAPD(error,TestStringL());
+ iTestHarness->EndTest(error);
+ User::LeaveIfError(error);
+ }
+
+void CWSPEncodeTest::TestStringL()
+ {
+ TBuf8<255> buf;
+
+ // Test 1. A regular string
+ const TUint8 KTestStringResult1[] = {'X','-','n','e','w','-','H','e','a','d','e','r','F','o','o',0x00};
+ _LIT8(KTestString1,"X-new-HeaderFoo");
+
+ // Test 2. A quoted string
+ const TUint8 KTestStringResult2[] = {'\"','X','-','n','e','w','-','H','e','a','d','e','r','F','o','o',0x00};
+ _LIT8(KTestString2,"\"X-new-HeaderFoo\"");
+
+ // Test 3. A string beginning with an Upper-Ascii character
+ const TUint8 KTestStringResult3[] = {0x7F,0x80,'X','-','n','e','w','-','H','e','a','d','e','r','F','o','o',0x00};
+ const TUint8 KTestString3[] = {0x80,'X','-','n','e','w','-','H','e','a','d','e','r','F','o','o'};
+
+ HBufC8* output = TWspPrimitiveEncoder::TextStringL(KTestString1);
+ CleanupStack::PushL(output);
+ buf.Copy(KTestStringResult1, sizeof(KTestStringResult1));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+
+ output = TWspPrimitiveEncoder::TextStringL(KTestString2);
+ CleanupStack::PushL(output);
+ buf.Copy(KTestStringResult2, sizeof(KTestStringResult2));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+
+ buf.Copy(KTestString3, sizeof(KTestString3));
+ output = TWspPrimitiveEncoder::TextStringL(buf);
+ CleanupStack::PushL(output);
+ buf.Copy(KTestStringResult3, sizeof(KTestStringResult3));
+ if ((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+ }
+
+
+void CWSPEncodeTest::DateTestL()
+ {
+ _LIT(KTestText, "WSP Encode: Date");
+ iTestHarness->StartTestL(KTestText);
+ TRAPD(error,TestDateL());
+ iTestHarness->EndTest(error);
+ User::LeaveIfError(error);
+ }
+
+
+void CWSPEncodeTest::TestDateL()
+ {
+ TBuf8<255> buf;
+
+ const TUint8 KDate0[] = {0x01, 0x00};
+
+ TDateTime date(1970,EJanuary,0,0,0,0,0);
+
+ HBufC8* output = TWspPrimitiveEncoder::DateL(date);
+ CleanupStack::PushL(output);
+ buf.Copy(KDate0, sizeof(KDate0));
+ if((*output).CompareF(buf)!=0)
+ User::Leave(KErrGeneral);
+ CleanupStack::PopAndDestroy(output);
+ }
+
+