telephonyserverplugins/ctsydispatchlayer/test/dispatchertests/dispatchsrc/cctsysupplementaryservicesfu.cpp
changeset 0 3553901f7fa8
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/telephonyserverplugins/ctsydispatchlayer/test/dispatchertests/dispatchsrc/cctsysupplementaryservicesfu.cpp	Tue Feb 02 01:41:59 2010 +0200
@@ -0,0 +1,1434 @@
+// Copyright (c) 2008-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:
+//
+
+
+
+/**
+ @file The TEFUnit test suite for SupplementaryServicesControl in the Common TSY.
+*/
+
+#include "cctsysupplementaryservicesfu.h"
+#include <etel.h>
+#include <etelmm.h>
+#include <et_clsvr.h>
+#include <ctsy/mmtsy_names.h>
+#include <ctsy/serviceapi/mmtsy_ipcdefs.h>
+#include <test/tmockltsydata.h>
+#include <ctsy/serviceapi/gsmerror.h>
+#include <ctsy/ltsy/mltsydispatchsupplementaryservicesinterface.h>
+#include "mockltsyindicatorids.h"
+#include <mmretrieve.h>
+#include <ctsy/rmmcustomapi.h>
+#include "cctsyactiveretriever.h"
+#include <ctsy/ltsy/mltsydispatchcallcontrolinterface.h>
+
+CTestSuite* CCTsySupplementaryServicesFU::CreateSuiteL(const TDesC& aName)
+	{
+	SUB_SUITE;
+
+	//add use-case tests
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUseCase0001L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUseCase0002L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUseCase0003L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUseCase0004L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUseCase0005L);
+  
+	//add other unit tests
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUnit0001L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUnit0002L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUnit0003L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUnit0004L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUnit0005L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUnit0006L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUnit0007L);
+	ADD_TEST_STEP_ISO_CPP(CCTsySupplementaryServicesFU, TestUnit0008L);
+
+	END_SUITE;
+	}
+
+
+//
+// Use-case tests
+//
+
+/**
+ * Compare two RMobilePhone::TMobileAddress objects.
+ * 
+ * @param aAddr1 the first object.
+ * @param aAddr2 the second object.
+ * @return ETrue iff the two object are the same.
+ * 
+ * */ 
+TBool operator ==(const RMobilePhone::TMobileAddress& aAddr1, 
+		const RMobilePhone::TMobileAddress& aAddr2)
+	{
+	if(aAddr1.iTypeOfNumber != aAddr2.iTypeOfNumber)
+		{
+		return EFalse;
+		}
+	if(aAddr1.iNumberPlan != aAddr2.iNumberPlan)
+		{
+		return EFalse;
+		}
+	if(aAddr1.iTelNumber != aAddr2.iTelNumber)
+		{
+		return EFalse;
+		}
+	return ETrue;
+	}
+
+/**
+ * Compare two RMobilePhone::TMobilePhoneCFInfoEntryV1 objects.
+ * 
+ * @param aEntry1 the first object.
+ * @param aEntry2 the second object.
+ * @return ETrue iff the two object are the same.
+ * 
+ * */ 
+TBool operator ==(const RMobilePhone::TMobilePhoneCFInfoEntryV1& aEntry1, 
+		const RMobilePhone::TMobilePhoneCFInfoEntryV1& aEntry2)
+	{
+	if(aEntry1.iCondition!=aEntry2.iCondition)
+		{
+		return EFalse;
+		}
+	if(aEntry1.iServiceGroup!=aEntry2.iServiceGroup)
+		{
+		return EFalse;
+		}
+	if(aEntry1.iStatus!=aEntry2.iStatus)
+		{
+		return EFalse;
+		}
+	if(!(aEntry1.iNumber==aEntry2.iNumber))
+		{
+		return EFalse;
+		}
+	if(aEntry1.iTimeout!=aEntry2.iTimeout)
+		{
+		return EFalse;
+		}
+	
+	return ETrue;
+	}
+
+/**
+ * Compare two RMobilePhone::TMobilePhoneCWInfoEntryV1 objects.
+ * 
+ * @param aEntry1 the first object.
+ * @param aEntry2 the second object.
+ * @return ETrue iff the two object are the same.
+ * 
+ * */ 
+TBool operator ==(const RMobilePhone::TMobilePhoneCWInfoEntryV1& aEntry1, 
+		const RMobilePhone::TMobilePhoneCWInfoEntryV1& aEntry2)
+	{
+	if(aEntry1.iStatus!=aEntry2.iStatus)
+		{
+		return EFalse;
+		}
+	if(aEntry1.iServiceGroup!=aEntry2.iServiceGroup)
+		{
+		return EFalse;
+		}
+	return ETrue;
+	}
+
+/**
+ * Compare two RMobilePhone::TMobilePhoneCWInfoEntryV1 objects.
+ * 
+ * @param aEntry1 the first object.
+ * @param aEntry2 the second object.
+ * @return ETrue iff the two object are the same.
+ * 
+ * */ 
+TBool operator ==(const RMobilePhone::TMobilePhoneCBInfoEntryV1& aEntry1, 
+		const RMobilePhone::TMobilePhoneCBInfoEntryV1& aEntry2)
+	{
+	if(aEntry1.iStatus!=aEntry2.iStatus)
+		{
+		return EFalse;
+		}
+	if(aEntry1.iCondition!=aEntry2.iCondition)
+		{
+		return EFalse;
+		}
+	if(aEntry1.iServiceGroup!=aEntry2.iServiceGroup)
+		{
+		return EFalse;
+		}
+	return ETrue;
+	}
+
+/**
+ * Compare two CMobilePhoneReadOnlyList objects.
+ * 
+ * @param aList1 the first object.
+ * @param aList2 the second object.
+ * @return ETrue iff the two object are the same.
+ * 
+ * */ 
+template<class T>
+TBool operator ==(const CMobilePhoneReadOnlyList<T>& aList1, 
+		const CMobilePhoneReadOnlyList<T>& aList2)
+	{
+	TInt size1 = aList1.Enumerate();
+	TInt size2 = aList2.Enumerate();
+	if(size1 != size2)
+		{
+		return EFalse;
+		}
+	for(TInt i = 0; i < size1; ++i)
+		{
+		if(!(aList1.GetEntryL(i) == aList2.GetEntryL(i)))
+			{
+			return EFalse;
+			}
+		}
+	return ETrue;
+	}
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UC0001
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for notify, set and get the call forwarding
+@SYMTestPriority High
+@SYMTestActions Invokes RMobilePhone::NotifyCallForwardingActive, RMobilePhone::NotifyCallForwardingStatusChange, RMobilePhone::SetCallForwardingStatus, CRetrieveMobilePhoneCFList::Start
+@SYMTestExpectedResults Pass
+@SYMTestType CT
+ */
+void CCTsySupplementaryServicesFU::TestUseCase0001L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);	
+
+	 
+	// post NotifyCallForwardingActive and NotifyCallForwardingStatusChange 
+	TRequestStatus notifyCallForwardingActiveStatus;
+	RMobilePhone::TMobileService service;
+	RMobilePhone::TMobilePhoneCFActive active;
+	iPhone.NotifyCallForwardingActive(notifyCallForwardingActiveStatus,service,active);
+	
+	TRequestStatus notifyCallForwardingStatusChangeStatus;
+	RMobilePhone::TMobilePhoneCFCondition notifyCondition;
+	iPhone.NotifyCallForwardingStatusChange(notifyCallForwardingStatusChangeStatus,notifyCondition);
+
+	// prepare ltsy to accept and answer the SetCallForwardingStatus
+	RMobilePhone::TMobilePhoneCFCondition setCondition = RMobilePhone::ECallForwardingNoReply;
+	RMobilePhone::TMobilePhoneCFChangeV1  callForwardinginfo;
+	callForwardinginfo.iAction = RMobilePhone::EServiceActionRegister;
+	callForwardinginfo.iNumber.iTypeOfNumber = RMobilePhone::EInternationalNumber;
+	callForwardinginfo.iNumber.iNumberPlan   = RMobilePhone::EIsdnNumberPlan;
+	_LIT(KTelNumber,"+74951000000");
+	callForwardinginfo.iNumber.iTelNumber.Copy(KTelNumber);
+	callForwardinginfo.iServiceGroup = RMobilePhone::EVoiceService;
+	callForwardinginfo.iTimeout = 20;
+	TMockLtsyData5<RMobilePhone::TMobilePhoneCFCondition, 
+	               RMobilePhone::TMobileService,
+	               RMobilePhone::TMobilePhoneServiceAction,
+	               TInt,
+	               TBuf<RMobilePhone::KMaxMobileTelNumberSize> > mockCompleteSetData(setCondition,
+	            		   callForwardinginfo.iServiceGroup,
+	            		   callForwardinginfo.iAction,
+	            		   callForwardinginfo.iTimeout,
+	            		   callForwardinginfo.iNumber.iTelNumber);
+	data.Close();
+	mockCompleteSetData.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesSetCallForwardingStatus::KLtsyDispatchSupplementaryServicesSetCallForwardingStatusApiId, data, KErrNone);
+	
+	// call to RMobilePhone::SetCallForwardingStatus
+	TRequestStatus requestStatusSet;
+	iPhone.SetCallForwardingStatus(requestStatusSet, setCondition, callForwardinginfo);
+	ASSERT_EQUALS(KRequestPending, notifyCallForwardingActiveStatus.Int());
+	ASSERT_EQUALS(KRequestPending, notifyCallForwardingStatusChangeStatus.Int());
+	ASSERT_EQUALS(KRequestPending, requestStatusSet.Int());
+
+	// complete NotifyCallForwardingStatusChange
+	RMobilePhone::TMobilePhoneCFCondition completeCondition = RMobilePhone::ECallForwardingNoReply;
+	TMockLtsyData1<RMobilePhone::TMobilePhoneCFCondition> mockCompleteNotifyCFStatusChangeData(completeCondition);
+	data.Close();
+	mockCompleteNotifyCFStatusChangeData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyCallForwardingStatusChangeIndId, KErrNone, data);
+	
+	//Wait for NotifyCallForwardingStatusChange
+	User::WaitForRequest(notifyCallForwardingStatusChangeStatus);
+	ASSERT_EQUALS(KErrNone, notifyCallForwardingStatusChangeStatus.Int());
+	ASSERT_EQUALS(KRequestPending, requestStatusSet.Int());
+	ASSERT_EQUALS(notifyCondition, completeCondition);
+	
+	// complete SetCallForwardingStatus
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesSetCallForwardingStatus::KLtsyDispatchSupplementaryServicesSetCallForwardingStatusApiId, KErrNone);
+	
+	//Wait for SetCallForwardingStatus
+	User::WaitForRequest(requestStatusSet);
+	ASSERT_EQUALS(KErrNone, requestStatusSet.Int());
+	
+	// complete notify NotifyCallForwardingActive
+	RMobilePhone::TMobileService completeService = callForwardinginfo.iServiceGroup;
+	RMobilePhone::TMobilePhoneCFActive completeActive = RMobilePhone::ECFConditionalActive;
+	TMockLtsyData2<RMobilePhone::TMobileService, RMobilePhone::TMobilePhoneCFActive> mockCompleteNotifyCFAData(completeService,completeActive);
+	data.Close();
+	mockCompleteNotifyCFAData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyCallForwardingActiveIndId, KErrNone, data);
+	
+	//Wait for NotifyCallForwardingActive
+	User::WaitForRequest(notifyCallForwardingActiveStatus);
+	ASSERT_EQUALS(KErrNone, notifyCallForwardingActiveStatus.Int());
+	ASSERT_EQUALS(service, completeService);
+	ASSERT_EQUALS(active, completeActive);
+	
+	// prepare ltsy to accept the CRetrieveMobilePhoneCFList::Start
+	
+	//CFilteringActiveScheduler does not need to be used, this should be changed
+	//to a listretrieverao type class
+	CFilteringActiveScheduler* scheduler = new (ELeave) CFilteringActiveScheduler();
+	CleanupStack::PushL(scheduler);
+	CActiveScheduler::Install(scheduler);
+	RMobilePhone::TMobilePhoneCFCondition getCondition = RMobilePhone::ECallForwardingBusy;
+	RMobilePhone::TMobileService getServiceGroup = RMobilePhone::EVoiceService;
+	TMockLtsyData2<RMobilePhone::TMobilePhoneCFCondition, RMobilePhone::TMobileService> mockCompleteGetData(getCondition,getServiceGroup);
+	data.Close();
+	mockCompleteGetData.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesGetCallForwardingStatus::KLtsyDispatchSupplementaryServicesGetCallForwardingStatusApiId, data, KErrNone);	
+
+	// Get the call forwarding list
+	TRequestStatus requestStatusGet;
+	RMobilePhone::TMobilePhoneCFCondition condition = getCondition;
+	RMobilePhone::TMobileService serviceGroup = getServiceGroup;
+	CRetrieveMobilePhoneCFList* asyncRetrieveMobilePhoneCFList =
+	                                       CRetrieveMobilePhoneCFList::NewL(iPhone);    
+	CleanupStack::PushL(asyncRetrieveMobilePhoneCFList);
+	CActiveRetriever::ResetRequestsNumber();
+	CActiveRetriever* activeRetriever = 
+						CActiveRetriever::NewL(*asyncRetrieveMobilePhoneCFList);
+	CleanupStack::PushL(activeRetriever);
+	scheduler->AddRetrieverL(*activeRetriever);
+	asyncRetrieveMobilePhoneCFList->Start(activeRetriever->iStatus, condition, serviceGroup);
+	activeRetriever->Activate();
+	
+	// Complete get call forwarding list
+	CMobilePhoneCFList* completeCFList = CMobilePhoneCFList::NewL();
+	CleanupStack::PushL(completeCFList);
+	RMobilePhone::TMobilePhoneCFInfoEntryV1	entryCFInfoEntry;
+	entryCFInfoEntry.iTimeout              = 20;
+	entryCFInfoEntry.iCondition            = RMobilePhone::ECallForwardingUnconditional;
+	entryCFInfoEntry.iServiceGroup         = RMobilePhone::EVoiceService;
+	entryCFInfoEntry.iStatus               = RMobilePhone::ECallForwardingStatusNotProvisioned;
+	entryCFInfoEntry.iNumber.iTypeOfNumber = RMobilePhone::EInternationalNumber;
+	entryCFInfoEntry.iNumber.iNumberPlan   = RMobilePhone::EIsdnNumberPlan;
+	entryCFInfoEntry.iNumber.iTelNumber.Copy(KTelNumber);
+	completeCFList->AddEntryL(entryCFInfoEntry);
+	entryCFInfoEntry.iTimeout              = 15;
+	entryCFInfoEntry.iCondition            = RMobilePhone::ECallForwardingNoReply;
+	entryCFInfoEntry.iServiceGroup         = RMobilePhone::EServiceUnspecified;
+	entryCFInfoEntry.iStatus               = RMobilePhone::ECallForwardingStatusActive;
+	entryCFInfoEntry.iNumber.iTypeOfNumber = RMobilePhone::ENationalNumber;
+	entryCFInfoEntry.iNumber.iNumberPlan   = RMobilePhone::ENationalNumberPlan;
+	_LIT(KTelNumber2,"123456789");
+	entryCFInfoEntry.iNumber.iTelNumber.Copy(KTelNumber2);
+	completeCFList->AddEntryL(entryCFInfoEntry);
+	CBufBase* completeCFListBuf = completeCFList->StoreLC();
+	data.Create(completeCFListBuf->Ptr(0));
+    iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesGetCallForwardingStatus::KLtsyDispatchSupplementaryServicesGetCallForwardingStatusApiId, KErrNone, data);
+
+	//Wait for CRetrieveMobilePhoneCFList::Start
+	scheduler->StartScheduler();
+	ASSERT_EQUALS(KErrNone, activeRetriever->iStatus.Int());
+	CMobilePhoneCFList *list = asyncRetrieveMobilePhoneCFList->RetrieveListL();
+	ASSERT_EQUALS(*completeCFList,*list);
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(7, this); // completeCFListBuf, completeCFList, activeRetriever, asyncRetrieveMobilePhoneCFList, scheduler, data, this
+	}
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UC0002
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for send a network service request string (with and without FDN check)
+@SYMTestPriority High
+@SYMTestActions Invokes RMobilePhone::SendNetworkServiceRequest, RMobilePhone::SendNetworkServiceRequestNoFdnCheck
+@SYMTestExpectedResults Pass
+@SYMTestType CT
+ */
+void CCTsySupplementaryServicesFU::TestUseCase0002L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);	
+
+	// prepare ltsy to accept and answer the SendNetworkServiceRequest
+	_LIT(KMsg1,"SendNetworkServiceRequest1.1");
+	TName expServiceString(KMsg1);
+ 	TMockLtsyData1<TName > expLtsyData(expServiceString);
+    expLtsyData.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesSendNetworkServiceRequest::KLtsyDispatchSupplementaryServicesSendNetworkServiceRequestApiId, data, KErrNone);
+	
+	// Send Network Service Request
+	TRequestStatus sendNetworkServiceRequestStatus;
+	iPhone.SendNetworkServiceRequest(sendNetworkServiceRequestStatus,expServiceString);
+	ASSERT_EQUALS(KRequestPending, sendNetworkServiceRequestStatus.Int());
+
+	// complete notify SendNetworkServiceRequest
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesSendNetworkServiceRequest::KLtsyDispatchSupplementaryServicesSendNetworkServiceRequestApiId, KErrNone);
+	
+	//Wait for NotifyCallForwardingActive
+	User::WaitForRequest(sendNetworkServiceRequestStatus);
+	ASSERT_EQUALS(KErrNone, sendNetworkServiceRequestStatus.Int());
+
+	// prepare ltsy to accept and answer the SendNetworkServiceRequestNoFdnCheck
+	_LIT(KMsg2,"SendNetworkServiceRequest1.2");
+	TName expServiceStringNoFDN(KMsg2);
+ 	TMockLtsyData1<TName > expLtsyDataNoFDN(expServiceStringNoFDN);
+ 	expLtsyDataNoFDN.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesSendNetworkServiceRequestNoFdnCheck::KLtsyDispatchSupplementaryServicesSendNetworkServiceRequestNoFdnCheckApiId, data, KErrNone);
+	
+	// Send Network Service Request
+	TRequestStatus sendNetworkServiceRequestNoFDNStatus;
+	iPhone.SendNetworkServiceRequestNoFdnCheck(sendNetworkServiceRequestNoFDNStatus,expServiceStringNoFDN);
+	ASSERT_EQUALS(KRequestPending, sendNetworkServiceRequestNoFDNStatus.Int());
+
+	// complete notify SendNetworkServiceRequestNoFDNCheck
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesSendNetworkServiceRequestNoFdnCheck::KLtsyDispatchSupplementaryServicesSendNetworkServiceRequestNoFdnCheckApiId, KErrNone);
+
+	//Wait for SendNetworkServiceRequestNoFDNCheck
+	User::WaitForRequest(sendNetworkServiceRequestNoFDNStatus);
+	ASSERT_EQUALS(KErrNone, sendNetworkServiceRequestNoFDNStatus.Int());
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(2, this); // data, this
+	}
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UC0003
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for send a USSD request to the network
+@SYMTestPriority High
+@SYMTestActions Invokes RMobileUssdMessaging::ReceiveMessage, RMobileUssdMessaging::SendMessage, RMobileUssdMessaging::SendRelease
+@SYMTestExpectedResults Pass
+@SYMTestType CT
+ */
+void CCTsySupplementaryServicesFU::TestUseCase0003L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);	
+	RMobileUssdMessaging ussdMessaging;
+	ASSERT_EQUALS(KErrNone, ussdMessaging.Open(iPhone));
+	CleanupClosePushL(ussdMessaging);
+
+	// Request CTSY to notify for USSD message
+	RMobileUssdMessaging::TGsmUssdMessageData recvData;
+	RMobileUssdMessaging::TMobileUssdAttributesV1 recvAttr; 
+	RMobileUssdMessaging::TMobileUssdAttributesV1Pckg recvAttrPckg(recvAttr);
+	TRequestStatus receiveMessageStatus;
+	ussdMessaging.ReceiveMessage(receiveMessageStatus,recvData,recvAttrPckg);
+	ASSERT_EQUALS(KRequestPending, receiveMessageStatus.Int());
+	
+	
+	// prepare ltsy to accept the SendMessage
+	_LIT8(KMsg1,"SendMessage1.1");
+	RMobileUssdMessaging::TGsmUssdMessageData expSendData(KMsg1);
+	RMobileUssdMessaging::TMobileUssdAttributesV1 expSendAttr;
+	expSendAttr.iDcs = 50;
+	expSendAttr.iFormat = RMobileUssdMessaging::EFormatUnspecified;
+	expSendAttr.iType = RMobileUssdMessaging::EUssdMORequest;
+	expSendAttr.iFlags = RMobileUssdMessaging::KUssdDataFormat | RMobileUssdMessaging::KUssdMessageType | RMobileUssdMessaging::KUssdMessageDcs;
+ 	TMockLtsyData2<RMobileUssdMessaging::TGsmUssdMessageData, RMobileUssdMessaging::TMobileUssdAttributesV1> expLtsySendData(expSendData, expSendAttr);
+ 	expLtsySendData.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesSendUssdMessage::KLtsyDispatchSupplementaryServicesSendUssdMessageApiId, data, KErrNone);
+	
+	// Send USSD Message
+	TRequestStatus sendMessageStatus;
+	RMobileUssdMessaging::TMobileUssdAttributesV1Pckg sendAttrPckg(expSendAttr);
+	ussdMessaging.SendMessage(sendMessageStatus,expSendData,sendAttrPckg);
+	ASSERT_EQUALS(KRequestPending, sendMessageStatus.Int());
+	ASSERT_EQUALS(KRequestPending, receiveMessageStatus.Int());
+
+	// complete SendMessage
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesSendUssdMessage::KLtsyDispatchSupplementaryServicesSendUssdMessageApiId, KErrNone);
+	
+	//Wait for SendMessage
+	User::WaitForRequest(sendMessageStatus);
+	ASSERT_EQUALS(KErrNone, sendMessageStatus.Int());
+	ASSERT_EQUALS(KRequestPending, receiveMessageStatus.Int());
+
+	// complete ReceiveMessage
+	_LIT8(KMsg2,"ReceiveMessage1.2");
+	TDesC8* messagePtr = const_cast<TDesC8*>(&KMsg2);
+	RMobileUssdMessaging::TMobileUssdAttributesV1 compRecvAttr;
+	compRecvAttr.iDcs = 16;
+	compRecvAttr.iFormat = RMobileUssdMessaging::EFormatUnspecified;
+	compRecvAttr.iType = RMobileUssdMessaging::EUssdMTReply;
+	compRecvAttr.iFlags = RMobileUssdMessaging::KUssdDataFormat | RMobileUssdMessaging::KUssdMessageType | RMobileUssdMessaging::KUssdMessageDcs;
+	TMockLtsyData2<TDesC8*, RMobileUssdMessaging::TMobileUssdAttributesV1> mockCompleteReceiveMessageData(messagePtr,compRecvAttr);
+	data.Close();
+	mockCompleteReceiveMessageData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesReceiveUssdMessageIndId, KErrNone, data);
+
+	//Wait for ReceiveMessage
+	User::WaitForRequest(receiveMessageStatus);
+	ASSERT_EQUALS(KErrNone, receiveMessageStatus.Int());
+	ASSERT_TRUE(recvData == *messagePtr);
+	ASSERT_EQUALS(recvAttr.iDcs, compRecvAttr.iDcs);
+	ASSERT_EQUALS(recvAttr.iFormat, compRecvAttr.iFormat);
+	ASSERT_EQUALS(recvAttr.iType, compRecvAttr.iType);
+	ASSERT_EQUALS(recvAttr.iFlags, compRecvAttr.iFlags);
+
+	// prepare ltsy to accept the SendRelease
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesSendUssdRelease::KLtsyDispatchSupplementaryServicesSendUssdReleaseApiId, KErrNone);
+	
+	// Send USSD Release
+	TRequestStatus sendReleaseStatus;
+	RMobilePhone::TMobilePhoneSendSSRequestV3 sendSSRequest;
+	RMobilePhone::TMobilePhoneSendSSRequestV3Pckg sendSSRequestPckg(sendSSRequest);
+	ussdMessaging.SendRelease(sendReleaseStatus,sendSSRequestPckg);
+	ASSERT_EQUALS(KRequestPending, sendReleaseStatus.Int());
+
+	// complete SendRelease
+	RMobilePhone::TMobilePhoneSendSSRequestV3 compSendSSRequest;
+	_LIT(KMsg3,"SendRelease1.3");
+	compSendSSRequest.iAdditionalInfo = KMsg3;
+	compSendSSRequest.iOpCode = 14;
+ 	TMockLtsyData1<RMobilePhone::TMobilePhoneSendSSRequestV3> expLtsySendRelease(compSendSSRequest);
+	data.Close();
+ 	expLtsySendRelease.SerialiseL(data);
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesSendUssdRelease::KLtsyDispatchSupplementaryServicesSendUssdReleaseApiId, KErrNone, data);
+	
+	//Wait for SendRelease
+	User::WaitForRequest(sendReleaseStatus);
+	ASSERT_EQUALS(KErrNone, sendReleaseStatus.Int());
+	// CTSY defect:  defect id 380202 in the component tests. SendRelease does not propogate the return values into ETEL  
+	//ASSERT_EQUALS(compSendSSRequest.iAdditionalInfo, sendSSRequest.iAdditionalInfo);
+	//ASSERT_EQUALS(compSendSSRequest.iOpCode, sendSSRequest.iOpCode);
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(3, this); // ussdMessaging, data, this
+	}
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UC0004
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for notify, set and get the call barring
+@SYMTestPriority High
+@SYMTestActions Invokes RMobilePhone::SetCallBarringStatus, RMobilePhone::NotifyCallBarringStatusChange, CRetrieveMobilePhoneCBList::Start
+@SYMTestExpectedResults Pass
+@SYMTestType CT
+ */
+void CCTsySupplementaryServicesFU::TestUseCase0004L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);	
+
+	// prepare ltsy to accept the CRetrieveMobilePhoneCBList::Start
+	
+	//CFilteringActiveScheduler does not need to be used, this should be changed
+	//to a listretrieverao type class
+	CFilteringActiveScheduler* scheduler = new (ELeave) CFilteringActiveScheduler();
+	CleanupStack::PushL(scheduler);
+	CActiveScheduler::Install(scheduler);
+	RMobilePhone::TMobilePhoneCBCondition getCondition = RMobilePhone::EBarOutgoingInternational;
+	TMockLtsyData1<RMobilePhone::TMobilePhoneCBCondition> mockCompleteGetData(getCondition);
+	data.Close();
+	mockCompleteGetData.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesGetCallBarringStatus::KLtsyDispatchSupplementaryServicesGetCallBarringStatusApiId, data, KErrNone);	
+
+	// Get the call barring list
+	TRequestStatus requestStatusGet;
+	RMobilePhone::TMobilePhoneCBCondition condition = getCondition;
+	CRetrieveMobilePhoneCBList* asyncRetrieveMobilePhoneCBList = CRetrieveMobilePhoneCBList::NewL(iPhone);    
+	CleanupStack::PushL(asyncRetrieveMobilePhoneCBList);
+	CActiveRetriever::ResetRequestsNumber();
+	CActiveRetriever* activeRetriever = 
+						CActiveRetriever::NewL(*asyncRetrieveMobilePhoneCBList);
+	CleanupStack::PushL(activeRetriever);
+	scheduler->AddRetrieverL(*activeRetriever);
+	asyncRetrieveMobilePhoneCBList->Start(activeRetriever->iStatus, condition);
+	activeRetriever->Activate();
+	
+	// Complete get call barring list
+	CMobilePhoneCBList* completeCBList = CMobilePhoneCBList::NewL();
+	CleanupStack::PushL(completeCBList);
+	RMobilePhone::TMobilePhoneCBInfoEntryV1	entryCBInfoEntry;
+	entryCBInfoEntry.iCondition = RMobilePhone::EBarOutgoingInternational;
+	entryCBInfoEntry.iStatus = RMobilePhone::ECallBarringStatusActive;
+	entryCBInfoEntry.iServiceGroup = RMobilePhone::EFaxService;
+	completeCBList->AddEntryL(entryCBInfoEntry);
+	entryCBInfoEntry.iCondition = RMobilePhone::EBarIncomingRoaming;
+	entryCBInfoEntry.iStatus = RMobilePhone::ECallBarringStatusNotProvisioned;
+	entryCBInfoEntry.iServiceGroup = RMobilePhone::EAllDataTele;
+	completeCBList->AddEntryL(entryCBInfoEntry);
+	CBufBase* completeCBListBuf = completeCBList->StoreLC();
+	data.Create(completeCBListBuf->Ptr(0));
+    iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesGetCallBarringStatus::KLtsyDispatchSupplementaryServicesGetCallBarringStatusApiId, KErrNone, data);
+
+	//Wait for CRetrieveMobilePhoneCBList::Start
+	scheduler->StartScheduler();
+	ASSERT_EQUALS(KErrNone, activeRetriever->iStatus.Int());
+	CMobilePhoneCBList *list = asyncRetrieveMobilePhoneCBList->RetrieveListL();
+	ASSERT_EQUALS(*completeCBList,*list);
+
+	// post NotifyCallBarringStatusChange 
+	TRequestStatus notifyCallBarringStatusChangeStatus;
+	RMobilePhone::TMobilePhoneCBCondition notifyCondition; 
+	iPhone.NotifyCallBarringStatusChange(notifyCallBarringStatusChangeStatus, notifyCondition);
+	ASSERT_EQUALS(KRequestPending, notifyCallBarringStatusChangeStatus.Int());
+
+	// prepare ltsy to accept and answer the SetCallBarringStatus
+	RMobilePhone::TMobilePhoneCBCondition setCondition = RMobilePhone::EBarIncomingRoaming;
+	RMobilePhone::TMobilePhoneCBChangeV1 setInfo;
+	setInfo.iAction = RMobilePhone::EServiceActionDeactivate;
+	setInfo.iServiceGroup = RMobilePhone::EPadAccess;
+	_LIT(KPassword,"1234");
+	setInfo.iPassword = KPassword;
+	TMockLtsyData2<RMobilePhone::TMobilePhoneCBCondition, RMobilePhone::TMobilePhoneCBChangeV1> mockCompleteSetData(setCondition,setInfo);
+	data.Close();
+	mockCompleteSetData.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesSetCallBarringStatus::KLtsyDispatchSupplementaryServicesSetCallBarringStatusApiId, data, KErrNone);
+	
+	// call to RMobilePhone::SetCallBarringStatus
+	TRequestStatus requestStatusSet;
+	iPhone.SetCallBarringStatus(requestStatusSet, setCondition, setInfo);
+	ASSERT_EQUALS(KRequestPending, notifyCallBarringStatusChangeStatus.Int());
+	ASSERT_EQUALS(KRequestPending, requestStatusSet.Int());
+
+	// complete SetCallBarringStatus
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesSetCallBarringStatus::KLtsyDispatchSupplementaryServicesSetCallBarringStatusApiId, KErrNone);
+	
+	//Wait for SetCallBarringStatus
+	User::WaitForRequest(requestStatusSet);
+	ASSERT_EQUALS(KRequestPending, notifyCallBarringStatusChangeStatus.Int());
+	ASSERT_EQUALS(KErrNone, requestStatusSet.Int());
+	
+	// complete NotifyCallBarringStatusChange
+	RMobilePhone::TMobilePhoneCBCondition completeCondition = RMobilePhone::EBarIncomingRoaming;
+	TMockLtsyData1<RMobilePhone::TMobilePhoneCBCondition> mockCompleteNotifyCallBarringStatusChangeData(completeCondition);
+	data.Close();
+	mockCompleteNotifyCallBarringStatusChangeData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyCallBarringStatusChangeIndId, KErrNone, data);
+	
+	//Wait for NotifyCallBarringStatusChange
+	User::WaitForRequest(notifyCallBarringStatusChangeStatus);
+	ASSERT_EQUALS(KErrNone, notifyCallBarringStatusChangeStatus.Int());
+	ASSERT_EQUALS(notifyCondition, completeCondition);
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(7, this); // completeCBListBuf, completeCBList, activeRetriever, asyncRetrieveMobilePhoneCBList, scheduler, data, this
+	}
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UC0005
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for notify, set and get the call waiting
+@SYMTestPriority High
+@SYMTestActions Invokes RMobilePhone::SetCallWaitingStatus, RMobilePhone::NotifyCallWaitingStatusChange, CRetrieveMobilePhoneCWList::Start
+@SYMTestExpectedResults Pass
+@SYMTestType CT
+ */
+void CCTsySupplementaryServicesFU::TestUseCase0005L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);	
+
+	// prepare ltsy to accept the CRetrieveMobilePhoneCWList::Start
+	
+	//CFilteringActiveScheduler does not need to be used, this should be changed
+	//to a listretrieverao type class
+	CFilteringActiveScheduler* scheduler = new (ELeave) CFilteringActiveScheduler();
+	CleanupStack::PushL(scheduler);
+	CActiveScheduler::Install(scheduler);
+	
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesGetCallWaitingStatus::KLtsyDispatchSupplementaryServicesGetCallWaitingStatusApiId, KErrNone);	
+
+	// Get the call waiting list
+	TRequestStatus requestStatusGet;
+	CRetrieveMobilePhoneCWList* asyncRetrieveMobilePhoneCWList = CRetrieveMobilePhoneCWList::NewL(iPhone);    
+	CleanupStack::PushL(asyncRetrieveMobilePhoneCWList);
+	CActiveRetriever::ResetRequestsNumber();
+	CActiveRetriever* activeRetriever = 
+						CActiveRetriever::NewL(*asyncRetrieveMobilePhoneCWList);
+	CleanupStack::PushL(activeRetriever);
+	scheduler->AddRetrieverL(*activeRetriever);
+	asyncRetrieveMobilePhoneCWList->Start(activeRetriever->iStatus);
+	activeRetriever->Activate();
+	
+	// Complete get call waiting list
+	CMobilePhoneCWList* completeCWList = CMobilePhoneCWList::NewL();
+	CleanupStack::PushL(completeCWList);
+	RMobilePhone::TMobilePhoneCWInfoEntryV1	entryCWInfoEntry;
+	entryCWInfoEntry.iStatus = RMobilePhone::ECallWaitingStatusActive;
+	entryCWInfoEntry.iServiceGroup = RMobilePhone::EFaxService;
+	completeCWList->AddEntryL(entryCWInfoEntry);
+	entryCWInfoEntry.iStatus = RMobilePhone::ECallWaitingStatusNotProvisioned;
+	entryCWInfoEntry.iServiceGroup = RMobilePhone::EAllDataTele;
+	completeCWList->AddEntryL(entryCWInfoEntry);
+	CBufBase* completeCWListBuf = completeCWList->StoreLC();
+	data.Create(completeCWListBuf->Ptr(0));
+    iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesGetCallWaitingStatus::KLtsyDispatchSupplementaryServicesGetCallWaitingStatusApiId, KErrNone, data);
+
+	//Wait for CRetrieveMobilePhoneCWList::Start
+	scheduler->StartScheduler();
+	ASSERT_EQUALS(KErrNone, activeRetriever->iStatus.Int());
+	CMobilePhoneCWList *list = asyncRetrieveMobilePhoneCWList->RetrieveListL();
+	ASSERT_EQUALS(*completeCWList,*list);
+
+	// post NotifyCallWaitingStatusChange
+	TRequestStatus notifyCallWaitingStatusChangeStatus;
+    RMobilePhone::TMobilePhoneCWInfoEntryV1 notifyResult;
+    RMobilePhone::TMobilePhoneCWInfoEntryV1Pckg notifyResultPckg(notifyResult);
+	iPhone.NotifyCallWaitingStatusChange(notifyCallWaitingStatusChangeStatus, notifyResultPckg);
+	ASSERT_EQUALS(KRequestPending, notifyCallWaitingStatusChangeStatus.Int());
+
+	// prepare ltsy to accept and answer the SetCallWaitingStatus
+    RMobilePhone::TMobileService setService = RMobilePhone::EPadAccess;
+    RMobilePhone::TMobilePhoneServiceAction setAction = RMobilePhone::EServiceActionActivate;
+	TMockLtsyData2<RMobilePhone::TMobileService, RMobilePhone::TMobilePhoneServiceAction> mockCompleteSetData(setService,setAction );
+	data.Close();
+	mockCompleteSetData.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesSetCallWaitingStatus::KLtsyDispatchSupplementaryServicesSetCallWaitingStatusApiId, data, KErrNone);
+	
+	// call to RMobilePhone::SetCallWaitingStatus
+	TRequestStatus requestStatusSet;
+	iPhone.SetCallWaitingStatus(requestStatusSet, setService, setAction);
+	ASSERT_EQUALS(KRequestPending, notifyCallWaitingStatusChangeStatus.Int());
+	ASSERT_EQUALS(KRequestPending, requestStatusSet.Int());
+
+	// complete SetCallWaitingStatus
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesSetCallWaitingStatus::KLtsyDispatchSupplementaryServicesSetCallWaitingStatusApiId, KErrNone);
+	
+	//Wait for SetCallWaitingStatus
+	User::WaitForRequest(requestStatusSet);
+	ASSERT_EQUALS(KRequestPending, notifyCallWaitingStatusChangeStatus.Int());
+	ASSERT_EQUALS(KErrNone, requestStatusSet.Int());
+	
+	// complete NotifyCallWaitingStatusChange
+	RMobilePhone::TMobileService completeService = RMobilePhone::EAllTele;
+    RMobilePhone::TMobilePhoneCWStatus completeStatus = RMobilePhone::ECallWaitingStatusNotAvailable;
+	TMockLtsyData2<RMobilePhone::TMobileService, RMobilePhone::TMobilePhoneCWStatus> mockCompleteNotifyCallWaitingStatusChangeData(completeService, completeStatus);
+	data.Close();
+	mockCompleteNotifyCallWaitingStatusChangeData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyCallWaitingStatusChangeIndId, KErrNone, data);
+	
+	//Wait for NotifyCallWaitingStatusChange
+	User::WaitForRequest(notifyCallWaitingStatusChangeStatus);
+	ASSERT_EQUALS(KErrNone, notifyCallWaitingStatusChangeStatus.Int());
+	ASSERT_EQUALS(notifyResult.iStatus, completeStatus);
+	ASSERT_EQUALS(notifyResult.iServiceGroup, completeService);
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(7, this); // completeCBListBuf, completeCBList, activeRetriever, asyncRetrieveMobilePhoneCBList, scheduler, data, this
+	}
+
+//
+// Other unit tests
+//
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UN0001
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for RMobilePhone::SetSSPassword
+@SYMTestPriority High
+@SYMTestActions Invokes RMobilePhone::SetSSPassword
+@SYMTestExpectedResults Pass
+@SYMTestType UT
+ */
+void CCTsySupplementaryServicesFU::TestUnit0001L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);
+	
+	// Prepare LTSY to answer RMobilePhone::SetSSPassword
+	_LIT(KOldPassword,"oldPswd");
+	_LIT(KNewPassword,"newPswd");
+	RMobilePhone::TMobilePhonePasswordChangeV2 pwdChange;
+	pwdChange.iOldPassword.Copy(KOldPassword);
+	pwdChange.iNewPassword.Copy(KNewPassword);
+	pwdChange.iVerifiedPassword.Copy(KNewPassword);
+	TPckg<RMobilePhone::TMobilePhonePasswordChangeV2> password(pwdChange);
+	MLtsyDispatchSupplementaryServicesSetSsPassword::TServiceType service = MLtsyDispatchSupplementaryServicesSetSsPassword::ECallBarring;
+	TMockLtsyData2<RMobilePhone::TMobilePhonePasswordChangeV2, MLtsyDispatchSupplementaryServicesSetSsPassword::TServiceType> ssData(pwdChange, service);
+	ssData.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesSetSsPassword::KLtsyDispatchSupplementaryServicesSetSsPasswordApiId, data, KErrNone);
+
+	// complete notify SetSSPassword
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesSetSsPassword::KLtsyDispatchSupplementaryServicesSetSsPasswordApiId, KErrNone);
+
+	// Send Network Service Request
+	TRequestStatus setSSPasswordStatus;
+	iPhone.SetSSPassword(setSSPasswordStatus,password,service);
+	ASSERT_EQUALS(KRequestPending, setSSPasswordStatus.Int());
+	
+	//Wait for SetSSPassword
+	User::WaitForRequest(setSSPasswordStatus);
+	ASSERT_EQUALS(KErrNone, setSSPasswordStatus.Int());
+
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(2, this); // data, this
+	
+	}
+	
+	
+	
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UN0002
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for RMmCustomAPI::ClearCallBlackList
+@SYMTestPriority High
+@SYMTestActions Invokes RMmCustomAPI::ClearCallBlackList
+@SYMTestExpectedResults Pass
+@SYMTestType UT
+ */
+void CCTsySupplementaryServicesFU::TestUnit0002L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);
+
+	RMmCustomAPI customApi;
+	OpenCustomApiLC(customApi);
+	
+	// Prepare LTSY to answer RMmCustomAPI::ClearCallBlackList
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesClearBlacklist::KLtsyDispatchSupplementaryServicesClearBlacklistApiId, KErrNone);
+
+	// complete ClearCallBlackList request
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesClearBlacklist::KLtsyDispatchSupplementaryServicesClearBlacklistApiId, KErrNone);
+
+	// Send Network Service Request
+	TRequestStatus clearBlacklistStatus;
+	customApi.ClearCallBlackList(clearBlacklistStatus);
+	ASSERT_EQUALS(KRequestPending, clearBlacklistStatus.Int());
+	
+	//Wait for ClearCallBlackList
+	User::WaitForRequest(clearBlacklistStatus);
+	ASSERT_EQUALS(KErrNone, clearBlacklistStatus.Int());
+
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(3, this); // customApi, data, this
+	
+	}
+	
+	
+
+
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UN0003
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for RMmCustomAPI::GetDiagnosticInfo
+@SYMTestPriority High
+@SYMTestActions Invokes RMmCustomAPI::GetDiagnosticInfo
+@SYMTestExpectedResults Pass
+@SYMTestType UT
+ */
+void CCTsySupplementaryServicesFU::TestUnit0003L()
+	{
+	// available causes, details in 3gpp 24.008 
+	static const TUint8 KDiagnosticInfoBarredWithCUG = 0x81;
+	static const TUint8 KDiagnosticInfoBarredNoCUG = 0x82;
+	static const TUint8 KDiagnosticInfoBarredUnknownCUG = 0x83;
+	static const TUint8 KDiagnosticInfoBarredIncompatibleCUG = 0x84;
+	static const TUint8 KDiagnosticInfoBarredFailureCUG = 0x85;
+	static const TUint8 KDiagnosticInfoBarredClirNotSubscribed = 0x86;
+	static const TUint8 KDiagnosticInfoBarredCCBSPossible = 0x87;
+	static const TUint8 KDiagnosticInfoBarredCCBSNotPossible = 0x88;
+	static const TUint8 KDiagnosticInfoBarredWrong = 0x89;
+	
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);
+
+	RMmCustomAPI customApi;
+	OpenCustomApiLC(customApi);
+	
+	TInt callId = 1;
+	DriverDialCallL(callId, RMobilePhone::EVoiceService);
+
+	RMobileLine mobileLine;
+	CleanupClosePushL(mobileLine);
+	RMobileCall mobileCall;
+	CleanupClosePushL(mobileCall);
+	ClientDialCallL(mobileLine, mobileCall, RMobilePhone::EVoiceService);
+
+	// Getting the call information
+	RMobileCall::TMobileCallInfoV1 callInfo;
+	RMobileCall::TMobileCallInfoV1Pckg callInfoPckg(callInfo);
+	ASSERT_EQUALS(KErrNone, mobileCall.GetMobileCallInfo(callInfoPckg));
+	ASSERT_EQUALS(callId , callInfo.iCallId);
+	
+	// Check GetDiagnosticInfo when no set was invoke
+	ASSERT_EQUALS(KErrNone, customApi.GetDiagnosticInfo(callInfo.iCallName));
+	
+	// Set the diagnostic octet to "Outgoing calls barred within CUG"
+	TRequestStatus terminatedStatus;
+	TUint8 cause = KDiagnosticInfoBarredWithCUG;
+	TMockLtsyData2<TInt, TUint8> diagData(callInfo.iCallId, cause);
+	diagData.SerialiseL(data);
+	iMockLTSY.NotifyTerminated(terminatedStatus);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesGetDiagnosticOctetsIndId, KErrNone, data);
+	User::WaitForRequest(terminatedStatus);
+
+	// Check GetDiagnosticInfo 
+	ASSERT_EQUALS(KErrDiagnosticInfoBarredWithCUG, customApi.GetDiagnosticInfo(callInfo.iCallName));
+
+	// Set the diagnostic octet to "No CUG selected"
+	cause = KDiagnosticInfoBarredNoCUG;
+	diagData.SerialiseL(data);
+	iMockLTSY.NotifyTerminated(terminatedStatus);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesGetDiagnosticOctetsIndId, KErrNone, data);
+	User::WaitForRequest(terminatedStatus);
+
+	// Check GetDiagnosticInfo 
+	ASSERT_EQUALS(KErrDiagnosticInfoBarredNoCUG, customApi.GetDiagnosticInfo(callInfo.iCallName));
+
+	// Set the diagnostic octet to "Unknown CUG index"
+	cause = KDiagnosticInfoBarredUnknownCUG;
+	diagData.SerialiseL(data);
+	iMockLTSY.NotifyTerminated(terminatedStatus);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesGetDiagnosticOctetsIndId, KErrNone, data);
+	User::WaitForRequest(terminatedStatus);
+
+	// Check GetDiagnosticInfo 
+	ASSERT_EQUALS(KErrDiagnosticInfoBarredUnknownCUG, customApi.GetDiagnosticInfo(callInfo.iCallName));
+
+	// Set the diagnostic octet to "CUG index incompatible with requested basic service"
+	cause = KDiagnosticInfoBarredIncompatibleCUG;
+	diagData.SerialiseL(data);
+	iMockLTSY.NotifyTerminated(terminatedStatus);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesGetDiagnosticOctetsIndId, KErrNone, data);
+	User::WaitForRequest(terminatedStatus);
+
+	// Check GetDiagnosticInfo 
+	ASSERT_EQUALS(KErrDiagnosticInfoBarredIncompatibleCUG, customApi.GetDiagnosticInfo(callInfo.iCallName));
+
+	// Set the diagnostic octet to "CUG call failure, unspecified"
+	cause = KDiagnosticInfoBarredFailureCUG;
+	diagData.SerialiseL(data);
+	iMockLTSY.NotifyTerminated(terminatedStatus);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesGetDiagnosticOctetsIndId, KErrNone, data);
+	User::WaitForRequest(terminatedStatus);
+
+	// Check GetDiagnosticInfo 
+	ASSERT_EQUALS(KErrDiagnosticInfoBarredFailureCUG, customApi.GetDiagnosticInfo(callInfo.iCallName));
+
+	// Set the diagnostic octet to "CLIR not subscribed"
+	cause = KDiagnosticInfoBarredClirNotSubscribed;
+	diagData.SerialiseL(data);
+	iMockLTSY.NotifyTerminated(terminatedStatus);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesGetDiagnosticOctetsIndId, KErrNone, data);
+	User::WaitForRequest(terminatedStatus);
+
+	// Check GetDiagnosticInfo 
+	ASSERT_EQUALS(KErrDiagnosticInfoBarredClirNotSubscribed, customApi.GetDiagnosticInfo(callInfo.iCallName));
+
+	// Set the diagnostic octet to "CCBS possible"
+	cause = KDiagnosticInfoBarredCCBSPossible;
+	diagData.SerialiseL(data);
+	iMockLTSY.NotifyTerminated(terminatedStatus);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesGetDiagnosticOctetsIndId, KErrNone, data);
+	User::WaitForRequest(terminatedStatus);
+
+	// Check GetDiagnosticInfo 
+	ASSERT_EQUALS(KErrDiagnosticInfoBarredCCBSPossible, customApi.GetDiagnosticInfo(callInfo.iCallName));
+
+	// Set the diagnostic octet to "CCBS not possible"
+	cause = KDiagnosticInfoBarredCCBSNotPossible;
+	diagData.SerialiseL(data);
+	iMockLTSY.NotifyTerminated(terminatedStatus);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesGetDiagnosticOctetsIndId, KErrNone, data);
+	User::WaitForRequest(terminatedStatus);
+
+	// Check GetDiagnosticInfo 
+	ASSERT_EQUALS(KErrDiagnosticInfoBarredCCBSNotPossible, customApi.GetDiagnosticInfo(callInfo.iCallName));
+
+	// Set the diagnostic octet to wrong value
+	cause = KDiagnosticInfoBarredWrong;
+	diagData.SerialiseL(data);
+	iMockLTSY.NotifyTerminated(terminatedStatus);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesGetDiagnosticOctetsIndId, KErrNone, data);
+	User::WaitForRequest(terminatedStatus);
+
+	// Check GetDiagnosticInfo 
+	ASSERT_EQUALS(KErrNone, customApi.GetDiagnosticInfo(callInfo.iCallName));
+
+	AssertMockLtsyStatusL();
+	
+	TInt hangUpCause = KErrGsmCCNormalCallClearing;
+	TMockLtsyData2<TInt, TInt> mockData2(callId, hangUpCause);
+	data.Close();
+	mockData2.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchCallControlHangUp::KLtsyDispatchCallControlHangUpApiId, data);
+	
+	CleanupStack::PopAndDestroy(5, this); // mobileCall, mobileLine, customApi, data, this
+	
+	}
+	
+
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UN0004
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for RMmCustomAPI::NotifySsNetworkEvent
+@SYMTestPriority High
+@SYMTestActions Invokes RMmCustomAPI::NotifySsNetworkEvent
+@SYMTestExpectedResults Pass
+@SYMTestType UT
+ */
+void CCTsySupplementaryServicesFU::TestUnit0004L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);
+
+	RMmCustomAPI customApi;
+	OpenCustomApiLC(customApi);
+	
+	// A. forward mode notification 
+	// register the notification
+	TRequestStatus requestStatus;
+	RMmCustomAPI::TSsTypeAndMode typeAndMode;
+	RMmCustomAPI::TSsInfo info;
+	customApi.NotifySsNetworkEvent(requestStatus, typeAndMode, info);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete NotifySsNetworkEvent
+	RMmCustomAPI::TSsForwMode compForwardInfo = RMmCustomAPI::ESsIncCallForwToC;
+	RMmCustomAPI::TSsTypeAndMode compTypeAndMode;
+	compTypeAndMode.iSsMode = RMmCustomAPI::ESsModeNotProvisioned;
+	compTypeAndMode.iSsType = RMmCustomAPI::ESsForwNoReach; 
+	
+	data.Close();
+	TMockLtsyData2<RMmCustomAPI::TSsTypeAndMode, RMmCustomAPI::TSsForwMode> compData1(compTypeAndMode, compForwardInfo);
+	compData1.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyNetworkEventForwardModeIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compForwardInfo, info.iForwMode);
+	ASSERT_EQUALS(compTypeAndMode.iSsMode, typeAndMode.iSsMode);
+	ASSERT_EQUALS(compTypeAndMode.iSsType, typeAndMode.iSsType);
+	
+	// B. call waiting notification 
+	// register the notification
+	customApi.NotifySsNetworkEvent(requestStatus, typeAndMode, info);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete NotifySsNetworkEvent
+	TBool compCallWaitingInfo = ETrue;
+	compTypeAndMode.iSsMode = RMmCustomAPI::ESsModeNotRegistered;
+	
+	data.Close();
+	TMockLtsyData2<RMmCustomAPI::TSsMode, TBool> compData2(compTypeAndMode.iSsMode, compCallWaitingInfo);
+	compData2.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyNetworkEventCallWaitingIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compCallWaitingInfo, info.iCallWait);
+	ASSERT_EQUALS(compTypeAndMode.iSsMode, typeAndMode.iSsMode);
+	ASSERT_EQUALS(RMmCustomAPI::ESsCallWaiting, typeAndMode.iSsType);
+	
+	// C. hold mode notification 
+	// register the notification
+	customApi.NotifySsNetworkEvent(requestStatus, typeAndMode, info);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete NotifySsNetworkEvent
+	RMmCustomAPI::TSsHoldMode compHoldMode = RMmCustomAPI::ESsHoldResume;
+	compTypeAndMode.iSsMode = RMmCustomAPI::ESsModeNotAvailable;
+	compTypeAndMode.iSsType = RMmCustomAPI::ESsBarrOutInterExcHome; 
+	
+	data.Close();
+	TMockLtsyData2<RMmCustomAPI::TSsTypeAndMode, RMmCustomAPI::TSsHoldMode> compData3(compTypeAndMode, compHoldMode);
+	compData3.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyNetworkEventHoldModeIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compHoldMode, info.iCallHold);
+	ASSERT_EQUALS(compTypeAndMode.iSsMode, typeAndMode.iSsMode);
+	ASSERT_EQUALS(compTypeAndMode.iSsType, typeAndMode.iSsType);
+	
+	// D. Confrence notification 
+	// register the notification
+	customApi.NotifySsNetworkEvent(requestStatus, typeAndMode, info);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete NotifySsNetworkEvent
+	TBool compConf = EFalse;
+	compTypeAndMode.iSsMode = RMmCustomAPI::ESsModeNotAvailable;
+	compTypeAndMode.iSsType = RMmCustomAPI::ESsBarrOutInterExcHome; 
+	
+	data.Close();
+	TMockLtsyData2<RMmCustomAPI::TSsTypeAndMode, TBool> compData4(compTypeAndMode, compConf);
+	compData4.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyNetworkEventConfrenceIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compConf, info.iConfInd);
+	ASSERT_EQUALS(compTypeAndMode.iSsMode, typeAndMode.iSsMode);
+	ASSERT_EQUALS(compTypeAndMode.iSsType, typeAndMode.iSsType);
+	
+	// E. Cug notification 
+	// register the notification
+	customApi.NotifySsNetworkEvent(requestStatus, typeAndMode, info);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete NotifySsNetworkEvent
+	TUint16 compCugIndex = 181;
+	compTypeAndMode.iSsMode = RMmCustomAPI::ESsModeActive;
+	compTypeAndMode.iSsType = RMmCustomAPI::ESsIncomingBarrServ; 
+	
+	data.Close();
+	TMockLtsyData2<RMmCustomAPI::TSsTypeAndMode, TUint16> compData5(compTypeAndMode, compCugIndex);
+	compData5.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyNetworkEventCugIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compCugIndex, info.iCugIndex);
+	ASSERT_EQUALS(compTypeAndMode.iSsMode, typeAndMode.iSsMode);
+	ASSERT_EQUALS(compTypeAndMode.iSsType, typeAndMode.iSsType);
+	
+	// F. Clir Suppression notification 
+	// register the notification
+	customApi.NotifySsNetworkEvent(requestStatus, typeAndMode, info);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete NotifySsNetworkEvent
+	TBool compClir = EFalse;
+	compTypeAndMode.iSsMode = RMmCustomAPI::ESsModeNotProvisioned;
+	
+	data.Close();
+	TMockLtsyData2<RMmCustomAPI::TSsMode, TBool> compData6(compTypeAndMode.iSsMode, compClir);
+	compData6.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyNetworkEventClirSuppressionIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compClir, info.iClirSuppReject);
+	ASSERT_EQUALS(compTypeAndMode.iSsMode, typeAndMode.iSsMode);
+	ASSERT_EQUALS(RMmCustomAPI::ESsClir, typeAndMode.iSsType);
+	
+	// G. Ect notification 
+	// register the notification
+	customApi.NotifySsNetworkEvent(requestStatus, typeAndMode, info);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete NotifySsNetworkEvent
+	RMmCustomAPI::TSsEctState compEctState = RMmCustomAPI::ESsEctAlerting;
+	RMmCustomAPI::TSsChoice compEctChoice = RMmCustomAPI::ESsPresRestrictedAddress;
+	_LIT(KRemoteAddress,"74951000123");
+	TBuf<RMmCustomAPI::KRemoteAddressSize> compRemoteAddress(KRemoteAddress); 
+	compTypeAndMode.iSsMode = RMmCustomAPI::ESsModeActive;
+	compTypeAndMode.iSsType = RMmCustomAPI::ESsIncomingBarrServ; 
+	
+	data.Close();
+	TMockLtsyData4<RMmCustomAPI::TSsTypeAndMode, RMmCustomAPI::TSsEctState, 
+	                  RMmCustomAPI::TSsChoice, TBuf<RMmCustomAPI::KRemoteAddressSize> > compData7(compTypeAndMode, compEctState, compEctChoice, compRemoteAddress);
+	compData7.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyNetworkEventEctCallStateIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compEctState, info.iEctCallState);
+	ASSERT_EQUALS(compEctChoice, info.iChoice);
+	ASSERT_EQUALS(compRemoteAddress, info.iRemoteAddress);
+	ASSERT_EQUALS(compTypeAndMode.iSsMode, typeAndMode.iSsMode);
+	ASSERT_EQUALS(compTypeAndMode.iSsType, typeAndMode.iSsType);
+	
+	// H. General notification 
+	// register the notification
+	customApi.NotifySsNetworkEvent(requestStatus, typeAndMode, info);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete NotifySsNetworkEvent
+	compTypeAndMode.iSsMode = RMmCustomAPI::ESsModeNotActive;
+	compTypeAndMode.iSsType = RMmCustomAPI::ESsColr; 
+	
+	data.Close();
+	TMockLtsyData1<RMmCustomAPI::TSsTypeAndMode> compData8(compTypeAndMode);
+	compData8.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyNetworkEventIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compTypeAndMode.iSsMode, typeAndMode.iSsMode);
+	ASSERT_EQUALS(compTypeAndMode.iSsType, typeAndMode.iSsType);
+	
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(3, this); // customApi, data, this
+	
+	}
+	
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UN0005
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for RMmCustomAPI::SsAdditionalInfoNotification
+@SYMTestPriority High
+@SYMTestActions Invokes RMmCustomAPI::SsAdditionalInfoNotification
+@SYMTestExpectedResults Pass
+@SYMTestType UT
+ */
+void CCTsySupplementaryServicesFU::TestUnit0005L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);
+
+	RMmCustomAPI customApi;
+	OpenCustomApiLC(customApi);
+	
+	// register the notification
+	TRequestStatus requestStatus;
+	RMmCustomAPI::TSsAdditionalInfo additionalInfo;
+	customApi.SsAdditionalInfoNotification(requestStatus, additionalInfo);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete SsAdditionalInfoNotification
+	RMmCustomAPI::TSsAdditionalInfo compAdditionalInfo;
+	compAdditionalInfo.iOperationCode = 74;
+	_LIT8(KAdditionalInfo, "Additional Info");
+	compAdditionalInfo.iAdditionalInfo = KAdditionalInfo;
+	TMockLtsyData1<RMmCustomAPI::TSsAdditionalInfo> compData(compAdditionalInfo);
+	compData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyAdditionalInfoIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compAdditionalInfo.iOperationCode, additionalInfo.iOperationCode);
+	ASSERT_EQUALS(compAdditionalInfo.iAdditionalInfo, additionalInfo.iAdditionalInfo);
+	
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(3, this); // customApi, data, this
+	
+	}
+
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UN0006
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for RMmCustomAPI::SsRequestCompleteNotification
+@SYMTestPriority High
+@SYMTestActions Invokes RMmCustomAPI::SsRequestCompleteNotification
+@SYMTestExpectedResults Pass
+@SYMTestType UT
+ */
+void CCTsySupplementaryServicesFU::TestUnit0006L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);
+
+	RMmCustomAPI customApi;
+	OpenCustomApiLC(customApi);
+	
+	// register the notification
+	TRequestStatus requestStatus;
+	TInt status;
+	customApi.SsRequestCompleteNotification(requestStatus, status);
+	ASSERT_EQUALS(KRequestPending, requestStatus.Int());
+
+	// complete SsAdditionalInfoNotification with an arbitrary status value (6812)
+	TInt compStatus = 6812;
+	TMockLtsyData1<TInt> compData(compStatus);
+	compData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifyRequestCompleteIndId, KErrNone, data);
+
+	// Check Notification
+	User::WaitForRequest(requestStatus);
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(compStatus, status);
+	
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(3, this); // customApi, data, this
+	}
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UN0007
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for RMobilePhone::NotifySendNetworkServiceRequest()
+@SYMTestPriority High
+@SYMTestActions Invokes RMobilePhone::NotifySendNetworkServiceRequest()
+@SYMTestExpectedResults Pass
+@SYMTestType UT
+ */
+void CCTsySupplementaryServicesFU::TestUnit0007L()
+	{
+	
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+
+	RBuf8 data;
+	CleanupClosePushL(data);
+	
+	OpenPhoneL();
+	
+	TRequestStatus reqStatus;
+	
+	//test the Notify in the KErrNone case
+	
+	RMobilePhone::TMobilePhoneNotifySendSSOperation operation = RMobilePhone::ESendSSReturnResult;
+	_LIT(KAddInfo,"ADDINFO");
+	
+
+	TDesC* additionalInfoPtr = const_cast<TDesC*>(&KAddInfo);
+	TMockLtsyData2<RMobilePhone::TMobilePhoneNotifySendSSOperation, TDesC*> notifySendNetworkServiceRequestCompData(operation,additionalInfoPtr);
+	notifySendNetworkServiceRequestCompData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifySendNetworkServiceRequestIndId, KErrNone, data);
+	data.Close();
+	
+	RMobilePhone::TMobilePhoneSendSSRequestV3 sendSsRequest;
+	RMobilePhone::TMobilePhoneSendSSRequestV3Pckg sendSsRequestPckg(sendSsRequest);
+	iPhone.NotifySendNetworkServiceRequest(reqStatus, operation, sendSsRequestPckg);
+	User::WaitForRequest(reqStatus);
+	ASSERT_EQUALS(reqStatus.Int(), KErrNone);
+	ASSERT_EQUALS(operation, static_cast<RMobilePhone::TMobilePhoneNotifySendSSOperation>(sendSsRequest.iOpCode));
+	ASSERT_TRUE(KAddInfo() == sendSsRequest.iAdditionalInfo);
+		
+	AssertMockLtsyStatusL();
+
+	//test the Notify in the KErrGeneral case
+	notifySendNetworkServiceRequestCompData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifySendNetworkServiceRequestIndId, KErrGeneral, data);
+	data.Close();
+
+	iPhone.NotifySendNetworkServiceRequest(reqStatus, operation, sendSsRequestPckg);
+	User::WaitForRequest(reqStatus);
+	ASSERT_EQUALS(reqStatus.Int(), KErrGeneral);
+
+	AssertMockLtsyStatusL();
+
+	//test the case where a indicator is sent up on an operation not being notified of.
+
+	//send up a indicator on a Operation we are not waiting on. 
+	operation = RMobilePhone::ESendSSInvoke;
+	notifySendNetworkServiceRequestCompData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifySendNetworkServiceRequestIndId, KErrNone, data);
+	data.Close();
+
+	//send up a indicator on a Operation we are waiting on. 
+	operation = RMobilePhone::ESendSSReturnResult;
+	notifySendNetworkServiceRequestCompData.SerialiseL(data);
+	iMockLTSY.CompleteL(KMockLtsyDispatchSupplementaryServicesNotifySendNetworkServiceRequestIndId, KErrNone, data);
+	data.Close();
+
+	RMobilePhone::TMobilePhoneSendSSRequestV3 sendSsRequest2;
+	RMobilePhone::TMobilePhoneSendSSRequestV3Pckg sendSsRequestPckg2(sendSsRequest2);
+	iPhone.NotifySendNetworkServiceRequest(reqStatus, operation, sendSsRequestPckg2);
+	User::WaitForRequest(reqStatus);
+	ASSERT_EQUALS(reqStatus.Int(), KErrNone);
+	ASSERT_EQUALS(operation, static_cast<RMobilePhone::TMobilePhoneNotifySendSSOperation>(sendSsRequest2.iOpCode));
+	ASSERT_TRUE(KAddInfo() == sendSsRequest2.iAdditionalInfo);
+	
+	AssertMockLtsyStatusL();
+		
+	CleanupStack::PopAndDestroy(&data);
+	CleanupStack::PopAndDestroy(this);
+	}
+
+
+/**
+@SYMTestCaseID BA-CTSYD-DIS-SUPPLEMENTARYSERVICES-UN0008
+@SYMComponent telephony_ctsy
+@SYMTestCaseDesc Test support in CTSY for send a USSD request to the network without FDN check
+@SYMTestPriority High
+@SYMTestActions Invokes RMobileUssdMessaging::SendMessage
+@SYMTestExpectedResults Pass
+@SYMTestType CT
+ */
+void CCTsySupplementaryServicesFU::TestUnit0008L()
+	{
+	OpenEtelServerL(EUseExtendedError);
+	CleanupStack::PushL(TCleanupItem(Cleanup,this));
+	OpenPhoneL();
+
+	RBuf8 data;
+	CleanupClosePushL(data);	
+	RMobileUssdMessaging ussdMessaging;
+	ASSERT_EQUALS(KErrNone, ussdMessaging.Open(iPhone));
+	CleanupClosePushL(ussdMessaging);
+
+	
+	// prepare ltsy to accept the SendMessage
+	_LIT8(KMsg1,"SendMessage1.1");
+	RMobileUssdMessaging::TGsmUssdMessageData expSendData(KMsg1);
+	RMobileUssdMessaging::TMobileUssdAttributesV1 expSendAttr;
+	expSendAttr.iDcs = 50;
+	expSendAttr.iFormat = RMobileUssdMessaging::EFormatUnspecified;
+	expSendAttr.iType = RMobileUssdMessaging::EUssdMORequest;
+	expSendAttr.iFlags = RMobileUssdMessaging::KUssdDataFormat | RMobileUssdMessaging::KUssdMessageType | RMobileUssdMessaging::KUssdMessageDcs;
+ 	TMockLtsyData2<RMobileUssdMessaging::TGsmUssdMessageData, RMobileUssdMessaging::TMobileUssdAttributesV1> expLtsySendData(expSendData, expSendAttr);
+ 	expLtsySendData.SerialiseL(data);
+	iMockLTSY.ExpectL(MLtsyDispatchSupplementaryServicesSendUssdMessageNoFdnCheck::KLtsyDispatchSupplementaryServicesSendUssdMessageNoFdnCheckApiId, data, KErrNone);
+	
+	// Send USSD Message
+	TRequestStatus sendMessageStatus;
+	RMobileUssdMessaging::TMobileUssdAttributesV1Pckg sendAttrPckg(expSendAttr);
+	ussdMessaging.SendMessageNoFdnCheck(sendMessageStatus,expSendData,sendAttrPckg);
+	ASSERT_EQUALS(KRequestPending, sendMessageStatus.Int());
+
+	// complete SendMessage
+	iMockLTSY.CompleteL(MLtsyDispatchSupplementaryServicesSendUssdMessageNoFdnCheck::KLtsyDispatchSupplementaryServicesSendUssdMessageNoFdnCheckApiId, KErrNone);
+	
+	//Wait for SendMessage
+	User::WaitForRequest(sendMessageStatus);
+	ASSERT_EQUALS(KErrNone, sendMessageStatus.Int());
+
+
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy(3, this); // ussdMessaging, data, this
+	}