diff -r 000000000000 -r 8e480a14352b messagingfw/msgtestfw/TestActions/Capabilities/src/CMtfTestActionSendEMsvMtmCommand.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/messagingfw/msgtestfw/TestActions/Capabilities/src/CMtfTestActionSendEMsvMtmCommand.cpp Mon Jan 18 20:36:02 2010 +0200 @@ -0,0 +1,323 @@ +// Copyright (c) 2004-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: +// + +#include "CMtfTestActionSendEMsvMtmCommand.h" + +#include +#include + +#include + +#include + // for KSMTPMTMIsConnected +#include + // For MTM's + +#include + // for ESmsMtmCommandReadSimParams + +#include "MCLIENT.H" +#include "MSERVER.H" + + + +#include "CMtfTestCase.h" +#include "CMtfTestActionParameters.h" + +#include "IPCCommandForCapsPermissions.h" +#include "SendProxyClient.h" +#include "SendProxyserver.h" + + +/** + Function : NewL + Description : + @internalTechnology + @param : aTestCase - CMtfTestCase for the CMtfTestAction base class + @param : aActionParams - CMtfTestActionParameters + @return : CMtfTestAction* - a base class pointer to the newly created CMtfTestActionSendEMsvMtmCommand object + @pre none + @post none +*/ +CMtfTestAction* CMtfTestActionSendEMsvMtmCommand::NewL(CMtfTestCase& aTestCase,CMtfTestActionParameters* aActionParameters) + { + CMtfTestActionSendEMsvMtmCommand* self = new (ELeave) CMtfTestActionSendEMsvMtmCommand(aTestCase); + CleanupStack::PushL(self); + self->ConstructL(aActionParameters); + CleanupStack::Pop(self); + return self; + } + +/** + Function : CMtfTestActionSendEMsvMtmCommand + Description : Constructor + @internalTechnology + @param : aTestCase - CMtfTestCase for the CMtfTestAction base class + @return : N/A + @pre none + @post none +*/ +CMtfTestActionSendEMsvMtmCommand::CMtfTestActionSendEMsvMtmCommand(CMtfTestCase& aTestCase) : CMtfSynchronousTestAction(aTestCase) + { + } + +/** + Function : ~CMtfTestActionSendEMsvMtmCommand + Description : Destructor + @internalTechnology + @param : + @return : + @pre + @post +*/ +CMtfTestActionSendEMsvMtmCommand::~CMtfTestActionSendEMsvMtmCommand() + { + } + +/** + Function : ExecuteActionL + Description : Entry point for the this test action in the test framework + @internalTechnology + @param : none + @return : void + @pre none + @post none +*/ + +void MTMCommandReportPassOrFailForCapsPermissions( CMtfTestCase& aTestCase, const TDesC& aTestName, TInt aError ,TInt aPass ) + { + + if ( aError == KErrDisconnected ) + { + if (aPass==1) + { + aTestCase.INFO_PRINTF2(_L("%S :: PASS :: Test Expected to Pass and Passes") , &aTestName ); + aTestCase.SetTestStepResult(EPass); + } + else if (aPass==0) + { + + aTestCase.ERR_PRINTF2(_L("%S :: FAIL :: Test Expected to Fail but Passes") , &aTestName ); + aTestCase.SetTestStepResult(EFail); + } + else + { + aTestCase.ERR_PRINTF2(_L("%S :: FAIL :: Should Specify PASS/FAIL") , &aTestName ); + aTestCase.SetTestStepResult(EFail); + } + } + else if ( aError == KErrPermissionDenied ) + { + if (aPass==1) + { + aTestCase.ERR_PRINTF2(_L("%S :: FAIL :: Test Expected to Pass but Fails") , &aTestName ); + aTestCase.SetTestStepResult(EFail); + } + else if (aPass==0) + { + aTestCase.INFO_PRINTF2(_L("%S :: PASS :: Test Expected to Fail and Passes") , &aTestName ); + aTestCase.SetTestStepResult(EPass); + } + else + { + aTestCase.ERR_PRINTF2(_L("%S :: FAIL :: Should Specify PASS/FAIL") , &aTestName ); + aTestCase.SetTestStepResult(EFail); + } + } + else + { + aTestCase.ERR_PRINTF3(_L("%S :: FAIL Unknown error (%d) ") , &aTestName , aError ); + aTestCase.SetTestStepResult(EFail); + } + + } + +void CdmaSmsMTMCommandReportPassOrFailForCapsPermissions( CMtfTestCase& aTestCase, const TDesC& aTestName, TInt aError ,TInt aPass ) + { + + if ( aError == KErrNotSupported ) + { + if (aPass==1) + { + aTestCase.INFO_PRINTF2(_L("%S :: PASS :: Test Expected to Pass and Passes") , &aTestName ); + aTestCase.SetTestStepResult(EPass); + } + else if (aPass==0) + { + + aTestCase.ERR_PRINTF2(_L("%S :: FAIL :: Test Expected to Fail but Passes") , &aTestName ); + aTestCase.SetTestStepResult(EFail); + } + else + { + aTestCase.ERR_PRINTF2(_L("%S :: FAIL :: Should Specify PASS/FAIL") , &aTestName ); + aTestCase.SetTestStepResult(EFail); + } + } + else if ( aError == KErrPermissionDenied ) + { + if (aPass==1) + { + aTestCase.ERR_PRINTF2(_L("%S :: FAIL :: Test Expected to Pass but Fails") , &aTestName ); + aTestCase.SetTestStepResult(EFail); + } + else if (aPass==0) + { + aTestCase.INFO_PRINTF2(_L("%S :: PASS :: Test Expected to Fail and Passes") , &aTestName ); + aTestCase.SetTestStepResult(EPass); + } + else + { + aTestCase.ERR_PRINTF2(_L("%S :: FAIL :: Should Specify PASS/FAIL") , &aTestName ); + aTestCase.SetTestStepResult(EFail); + } + } + else + { + aTestCase.ERR_PRINTF3(_L("%S :: FAIL Unknown error (%d) ") , &aTestName , aError ); + aTestCase.SetTestStepResult(EFail); + } + } + +void CMtfTestActionSendEMsvMtmCommand::ExecuteActionL() + { + TestCase().INFO_PRINTF2(_L("Test Action %S start..."), &KTestActionSendEMsvMtmCommand); + // input params + + CBaseMtm* paramMtm = ObtainParameterReferenceL(TestCase(),ActionParameters().Parameter(0)); + TInt pass = ObtainValueParameterL(TestCase(),ActionParameters().Parameter(1) ); + + + RProxyServerSession RPSS; + TInt error = RPSS.Connect(); + // Will auto start the server if not started. + + if (error!=KErrNone) + { + TestCase().ERR_PRINTF2(_L("%S :: FAIL :: Unable to start proxy server. !"), &KTestActionSendEMsvMtmCommand); + TestCase().SetTestStepResult(EFail); + } + else + { + TInt32 serverCaps; + RPSS.GetServerCapabilities(serverCaps); + TestCase().INFO_PRINTF2(_L("Proxy Server has capabilities: %x"), serverCaps); + + TInt error = 0; + CleanupClosePushL(RPSS); + + + HBufC8* buffer = HBufC8::NewLC(KMsvSessionBufferLength); + + CMsvEntrySelection* entrySelection = new (ELeave) (CMsvEntrySelection); + CleanupDeletePushL(entrySelection); + + entrySelection->SetReserveL(1); + + CMsvEntry& entry = paramMtm->Entry(); + entrySelection->AppendL(entry.EntryId()); + + TMsvPackedOperation packedOperation(buffer); + + if (paramMtm->Type() != KUidMsgTypeSMS) + { + error = packedOperation.Pack(*entrySelection, KSMTPMTMIsConnected); + } + else + { + error = packedOperation.Pack(*entrySelection, ESmsMtmCommandReadSimParams); + } + + if (error) + { + TestCase().ERR_PRINTF2(_L("%S :: FAIL :: Unable to pack the message") , &KTestActionSendEMsvMtmCommand ); + TestCase().SetTestStepResult(EFail); + User::LeaveIfError(error); + } + + TMsvOp operationId=1; + TBuf8<32> param; + + + error=RPSS.SendReceive(EMsvCommandData, TIpcArgs(operationId, buffer, ¶m)); + if (error) + { + TestCase().ERR_PRINTF2(_L("%S :: FAIL :: Unable to send the message data") , &KTestActionSendEMsvMtmCommand ); + TestCase().SetTestStepResult(EFail); + User::LeaveIfError(error); + } + + error=RPSS.SendReceive(EMsvMtmCommand , TIpcArgs(operationId) ); + // We always expect + // KErrDisconnected (-36) as we have never made a connection to the SMTP server. + // or KErrPermissionDenied if the caps checking finds problems. + + + if (paramMtm->Type() != KUidMsgTypeSMS) + { + MTMCommandReportPassOrFailForCapsPermissions( TestCase(), KTestActionSendEMsvMtmCommand, error , pass ); + + if ( (pass==0) && (error!=KErrDisconnected) ) + { // expected to fail and does fail should not cancel. + } + else + { + TBuf8<64> complete; + TInt ret =RPSS.SendReceive(EMsvCancelOperation , + TIpcArgs(operationId, &complete ) ); + // Now lets cancel to stop any panic. We will have data in buffers etc that needs to cleaned out. + + if (ret>=0) + { // We are happy some sort of length returned. + } + else if (ret<0) + { + TestCase().ERR_PRINTF2(_L("%S :: FAIL :: Unable to cancel command") , &KTestActionSendEMsvMtmCommand ); + TestCase().SetTestStepResult(EFail); + User::LeaveIfError(error); + } + } + } + else + { // Cdma Sms Mtm is used + CdmaSmsMTMCommandReportPassOrFailForCapsPermissions( TestCase(), KTestActionSendEMsvMtmCommand, error , pass ); + + if (error == KErrNone) + { + // Now lets cancel to stop any panic, KErrNone is not expected + TBuf8<64> complete; + TInt ret =RPSS.SendReceive(EMsvCancelOperation , + TIpcArgs(operationId, &complete ) ); + + TestCase().ERR_PRINTF2(_L("%S :: FAIL :: Unable to cancel command") , &KTestActionSendEMsvMtmCommand ); + TestCase().SetTestStepResult(EFail); + } + } + + CleanupStack::Check(entrySelection); + CleanupStack::PopAndDestroy(); + + CleanupStack::Check(buffer); + CleanupStack::PopAndDestroy(); + + CleanupStack::Check(&RPSS); + CleanupStack::PopAndDestroy(); + } + + + TestCase().INFO_PRINTF2(_L("Test Action %S completed."), &KTestActionSendEMsvMtmCommand); + TestCase().ActionCompletedL(*this); + + }