email/imap4mtm/imapsession/test/src/ctestimapcommand.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 11 May 2010 16:10:04 +0300
branchRCL_3
changeset 28 fbb813aef148
parent 0 72b543305e3a
permissions -rw-r--r--
Revision: 201017 Kit: 201019

// Copyright (c) 2006-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:
// ctestimapcommnad.cpp
// 
//

#include "ctestimapcommand.h"

#include "cfakeinputstream.h"
#include "cfakeoutputstream.h"
#include "cactivewaiter.h"

#include "moutputstream.h"

#include "cimapsession.h"
#include "cimapsessionconsts.h"
#include "cimaputils.h"

CTestImapCommand::CTestImapCommand()
	: iInputStream(NULL)
	, iOutputStream(NULL)
	, iActiveWaiter(NULL)
	, iImapSession(NULL)
	{}

CTestImapCommand::~CTestImapCommand()
	{
	delete iImapSession;
	delete iActiveWaiter;
	delete iOutputStream;
	delete iInputStream;
	CImapUtils::Delete();
	}

void CTestImapCommand::SetupL()
	{
	ASSERT(iInputStream == NULL);
	ASSERT(iOutputStream == NULL);
	ASSERT(iActiveWaiter == NULL);
	ASSERT(iImapSession == NULL);

	CImapUtils::CreateL();
	iInputStream = CFakeInputStream::NewL(Logger());
	iOutputStream = CFakeOutputStream::NewL(Logger());
	iActiveWaiter = new(ELeave)CActiveWaiter(Logger());
	
	CImapSettings* imapSettings=NULL;
	CImapMailStore* imapMailStore=NULL;
	
	iImapSession = CImapSession::NewL(*imapSettings, *imapMailStore, *iInputStream, *iOutputStream);
	
	SetupServerGreetingL();
	}
	
void CTestImapCommand::TearDownL()
	{
	delete iImapSession;
	iImapSession = NULL;
	
	delete iActiveWaiter;
	iActiveWaiter = NULL;
	
	delete iOutputStream;
	iOutputStream = NULL;
	
	delete iInputStream;
	iInputStream = NULL;

	CImapUtils::Delete();
	}

void CTestImapCommand::SetupServerGreetingL()
	{
	INFO_PRINTF1(_L("Setup: ServerGreeting"));
	iInputStream->ResetInputStrings();
	iInputStream->AppendInputStringL(_L8("* OK Microsoft Exchange 2000 IMAP4rev1 server version 6.0.6249.0 (lon-cn-exchng2k.msexchange2k.closedtest.intra) ready.\r\n"));

	ASSERT_EQUALS(CImapSession::EServerStateNone, iImapSession->ServerState());
	
	iImapSession->ReadServerGreetingL(iActiveWaiter->iStatus);
	iActiveWaiter->WaitActive();
	
	ASSERT_EQUALS(CImapSession::EServerStateNotAuthenticated, iImapSession->ServerState());
	
	INFO_PRINTF1(_L("Setup: Complete"));
	}

// Tests
void CTestImapCommand::TestTaggedOkOnlyL()
	{
	INFO_PRINTF1(_L("TestTaggedOkOnlyL"));
	
	iInputStream->ResetInputStrings();
	iInputStream->AppendInputStringL(_L8("1 OK LOGOUT completed\r\n"));
	
	iImapSession->LogoutL(iActiveWaiter->iStatus);
	iActiveWaiter->WaitActive();
	
	INFO_PRINTF1(_L("Complete"));
	}
	
void CTestImapCommand::TestTaggedNoL()
	{
	INFO_PRINTF1(_L("TestTaggedNoL"));
	
	iInputStream->ResetInputStrings();
	iInputStream->AppendInputStringL(_L8("1 NO LOGOUT not allowed right now\r\n"));
	
	iImapSession->LogoutL(iActiveWaiter->iStatus);
	iActiveWaiter->WaitActive(KErrImapNo);
	
	INFO_PRINTF1(_L("Complete"));
	}
	
void CTestImapCommand::TestTaggedBadL()
	{
	INFO_PRINTF1(_L("TestTaggedBadL"));
	
	iInputStream->ResetInputStrings();
	iInputStream->AppendInputStringL(_L8("1 BAD malformed just testing\r\n"));
	
	iImapSession->LogoutL(iActiveWaiter->iStatus);
	iActiveWaiter->WaitActive(KErrImapBad);
	
	INFO_PRINTF1(_L("Complete"));
	}
	
void CTestImapCommand::TestKnownThenTaggedOkL()
	{
	INFO_PRINTF1(_L("TestKnownThenTaggedOkL"));
	
	iInputStream->ResetInputStrings();
	iInputStream->AppendInputStringL(_L8("* BYE IMAP4rev1 Server logging out\r\n"));
	iInputStream->AppendInputStringL(_L8("1 OK LOGOUT completed\r\n"));
	
	iImapSession->LogoutL(iActiveWaiter->iStatus);
	iActiveWaiter->WaitActive();
	
	INFO_PRINTF1(_L("Complete"));
	}
	
void CTestImapCommand::TestUnilateralThenTaggedOkL()
	{
	INFO_PRINTF1(_L("TestUnilateralThenTaggedOkL"));
	
	iInputStream->ResetInputStrings();
	iInputStream->AppendInputStringL(_L8("* 23 EXISTS\r\n"));
	iInputStream->AppendInputStringL(_L8("1 OK LOGOUT completed\r\n"));
		
	iImapSession->LogoutL(iActiveWaiter->iStatus);
	iActiveWaiter->WaitActive();
	
	INFO_PRINTF1(_L("Complete"));
	}

void CTestImapCommand::TestUnknownLineThenTaggedOkL()
	{
	INFO_PRINTF1(_L("TestUnknownLineThenTaggedOkL"));
		
	iInputStream->ResetInputStrings();
	// Emulates a one-line extension response
	iInputStream->AppendInputStringL(_L8("* XWIBBLE wobble\r\n"));
	iInputStream->AppendInputStringL(_L8("1 OK LOGOUT completed\r\n"));
		
	iImapSession->LogoutL(iActiveWaiter->iStatus);
	iActiveWaiter->WaitActive();
	
	INFO_PRINTF1(_L("Complete"));
	}

void CTestImapCommand::TestUnknownLiteralThenTaggedOkL()
	{
	INFO_PRINTF1(_L("TestUnknownLiteralThenTaggedOkL"));
	
	iInputStream->ResetInputStrings();
	// Emulates a server-pushed FETCH (which we don't handle)
	iInputStream->AppendInputStringL(_L8("* 1 FETCH (BODY[1]<0> {19}\r\n"));
	iInputStream->AppendInputStringL(_L8("a small test body\r\n"));
	iInputStream->AppendInputStringL(_L8("UID 2717 FLAGS (\\Seen))\r\n"));
	iInputStream->AppendInputStringL(_L8("1 OK LOGOUT completed\r\n"));
		
	iImapSession->LogoutL(iActiveWaiter->iStatus);
	iActiveWaiter->WaitActive();
	
	INFO_PRINTF1(_L("Complete"));
	}

void CTestImapCommand::TestUnknownMultiLiteralThenTaggedOkL()
	{
	INFO_PRINTF1(_L("TestUnknownMultiLiteralThenTaggedOkL"));
	// Emulates a server-pushed FETCH (which we don't handle), with two literals
	iInputStream->ResetInputStrings();
	iInputStream->AppendInputStringL(_L8("* 1 FETCH (BODY[1]<0> {19}\r\n"));
	iInputStream->AppendInputStringL(_L8("a small test body\r\n"));
	iInputStream->AppendInputStringL(_L8(" BODY[1.MIME] {766}\r\n"));
	iInputStream->AppendInputStringL(_L8("Received: from LONDAVIDS02 ([10.23.152.33]) by msexchange2k.closedtest.intra with Microsoft SMTPSVC(5.0.2195.6713);\r\n"));
	iInputStream->AppendInputStringL(_L8("	 Wed, 22 Mar 2006 14:43:56 +0000\r\n"));
	iInputStream->AppendInputStringL(_L8("Message-ID: <001901c64dbf$c42ec6d0$0100a8c0@intra>\r\n"));
	iInputStream->AppendInputStringL(_L8("From: \"IMAP\" <davids@msexchange2k.closedtest.intra>\r\n"));
	iInputStream->AppendInputStringL(_L8("To: \"David Test Account\" <davids@msexchange2k.closedtest.intra>\r\n"));
	iInputStream->AppendInputStringL(_L8("Subject: t1\r\n"));
	iInputStream->AppendInputStringL(_L8("Date: Wed, 22 Mar 2006 14:49:05 -0000\r\n"));
	iInputStream->AppendInputStringL(_L8("MIME-Version: 1.0\r\n"));
	iInputStream->AppendInputStringL(_L8("Content-Type: text/plain;\r\n"));
	iInputStream->AppendInputStringL(_L8("	charset=\"iso-8859-1\"\r\n"));
	iInputStream->AppendInputStringL(_L8("Content-Transfer-Encoding: 7bit\r\n"));
	iInputStream->AppendInputStringL(_L8("X-Priority: 3\r\n"));
	iInputStream->AppendInputStringL(_L8("X-MSMail-Priority: Normal\r\n"));
	iInputStream->AppendInputStringL(_L8("X-Mailer: Microsoft Outlook Express 6.00.2800.1506\r\n"));
	iInputStream->AppendInputStringL(_L8("X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2800.1506\r\n"));
	iInputStream->AppendInputStringL(_L8("Return-Path: davids@msexchange2k.closedtest.intra\r\n"));
	iInputStream->AppendInputStringL(_L8("X-OriginalArrivalTime: 22 Mar 2006 14:43:56.0562 (UTC) FILETIME=[0C365F20:01C64DBF]\r\n"));
	iInputStream->AppendInputStringL(_L8("\r\n"));
	iInputStream->AppendInputStringL(_L8(" UID 2717 FLAGS (\\Seen))\r\n"));
	// Let's have an extra (known) untagged response, too
	iInputStream->AppendInputStringL(_L8("* BYE IMAP4rev1 Server logging out\r\n"));
	// And finally, the tagged response
	iInputStream->AppendInputStringL(_L8("1 OK LOGOUT completed\r\n"));
		
	iImapSession->LogoutL(iActiveWaiter->iStatus);
	iActiveWaiter->WaitActive();

	// Not in the selected state, so not folder info
	CImapFolderInfo* folderInfo = iImapSession->SelectedFolderInfo();
	ASSERT_NULL(folderInfo);
	
	INFO_PRINTF1(_L("Complete"));
	}
	
void CTestImapCommand::TestEncodeMailboxsL()
	{
	INFO_PRINTF1(_L("TestEncodeMailboxL"));
	
	DoTestEncodeMailboxL(_L16("inbox"), _L8("inbox"));
	DoTestEncodeMailboxL(_L16("inbox/folder"), _L8("inbox/folder"));
	DoTestEncodeMailboxL(_L16("inbox\\folder"), _L8("\"inbox\\\\folder\""));
	DoTestEncodeMailboxL(_L16("my folder"), _L8("\"my folder\""));
	DoTestEncodeMailboxL(_L16("daft folder name with \"newline\"\r\nand a smily face \x263a symbol"), _L8("\"daft folder name with \\\"newline\\\"&AA0ACg-and a smily face &Jjo- symbol\""));
	DoTestEncodeMailboxL(_L16("bits&pieces"), _L8("bits&-pieces"));
	DoTestEncodeMailboxL(_L16("smiley:\x263a"), _L8("smiley:&Jjo-"));
	DoTestEncodeMailboxL(_L16("folder[square]"), _L8("\"folder[square]\""));
	DoTestEncodeMailboxL(_L16("toplevel"), _L8("toplevel"));
	
	INFO_PRINTF1(_L("Complete"));
	}
	
void CTestImapCommand::DoTestEncodeMailboxL(const TDesC16& aUnicode, const TDesC8& aExpectedEncoding)
	{
	HBufC8* encodedMailbox = CImapCommand::EncodeMailboxNameForSendL(aUnicode);
	CleanupStack::PushL(encodedMailbox);
	
	ASSERT_EQUALS((const TDesC8&)*encodedMailbox, aExpectedEncoding);
	
	CleanupStack::PopAndDestroy();
	}

CTestSuite* CTestImapCommand::CreateSuiteL(const TDesC& aName)
// static
	{
	SUB_SUITE;
	ADD_ASYNC_TEST_STEP(TestTaggedOkOnlyL);
	ADD_ASYNC_TEST_STEP(TestTaggedNoL);
	ADD_ASYNC_TEST_STEP(TestTaggedBadL);
	ADD_ASYNC_TEST_STEP(TestKnownThenTaggedOkL);
	ADD_ASYNC_TEST_STEP(TestUnilateralThenTaggedOkL);
	ADD_ASYNC_TEST_STEP(TestUnknownLineThenTaggedOkL);
	ADD_ASYNC_TEST_STEP(TestUnknownLiteralThenTaggedOkL);
	ADD_ASYNC_TEST_STEP(TestUnknownMultiLiteralThenTaggedOkL);
	ADD_ASYNC_TEST_STEP(TestEncodeMailboxsL);
	END_SUITE;
	}