genericservices/httputils/Test/t_wspcodec/cwspencodetest.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 04 Oct 2010 02:56:42 +0300
changeset 68 ff3fc7722556
parent 0 e4d67989cc36
permissions -rw-r--r--
Revision: 201039 Kit: 201039

// 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);
	}