telephonyserverplugins/simtsy/test/Te_SimVoice/Te_SimVoice.cpp
branchopencode
changeset 24 6638e7f4bd8f
parent 0 3553901f7fa8
--- a/telephonyserverplugins/simtsy/test/Te_SimVoice/Te_SimVoice.cpp	Mon May 03 13:37:20 2010 +0300
+++ b/telephonyserverplugins/simtsy/test/Te_SimVoice/Te_SimVoice.cpp	Thu May 06 15:10:38 2010 +0100
@@ -1,2513 +1,2513 @@
-// Copyright (c) 2003-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
-*/
-
-#include "Te_SimVoice.h"
-
-const TInt KTenPartOfSec = 100000 ;
-const TInt KOneSecond=1000000;	// Used in a time out function, 1 second (in microSeconds)
-const TInt KTenSeconds=10000000;	// Used in a time out function, 10 seconds (in microSeconds)
- 
-//------------------------------------------------------------------
-
-CTestLineStatusIncommingCall::CTestLineStatusIncommingCall()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestLineStatusIncommingCall"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestLineStatusIncommingCall::doTestStepL()
-/**	 Tests line status function
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-004.00 Test retrieval of a voice line's current status (Generic)
- * @test GT83-TVOICE-004.02 "Test retrieval of a voice line's current status when the line's status is ""Idle"""
- * @test GT83-TVOICE-004.04 "Test retrieval of a voice line's current status when the line's status is ""Ringing"""
- * @test GT83-TVOICE-004.07 "Test retrieval of a voice line's current status when the line's status is ""Connected"""
- * @test GT83-TVOICE-004.08 "Test retrieval of a voice line's current status when the line's status is ""Hanging up"""
- * @test GT83-TVOICE-008.02 Test for a notification when there is an incoming call on a voice line
- * @test GT83-TVOICE-015.05 Test opening an existing call from a voice line by specifying the name of the line and the name of an existing call
- * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
- * @test GT83-TVOICE-030.00 Test retrieval of a mobile voice line's current status (Generic)
- * @test GT83-TVOICE-030.02 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""Dialling"""
- * @test GT83-TVOICE-030.03 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""Ringing"""
- * @test GT83-TVOICE-030.06 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""Disconnecting"""
- * @test GT83-TVOICE-030.07 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""on hold"""
- * @test GT83-TVOICE-031.01 Test setting a request for a notification of a change in the status of the mobile voice line
-*/
-{
-	INFO_PRINTF1(_L("Test Line Status"));
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	TName callName;
-
-	RCall::TStatus lineStatus;
-	TBuf<16> GoodNumber ;
-	GetGoodNumber(GoodNumber) ;
-	// Open a Voice Line and Call
-	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
-
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	/* @test GT83-AT-36	Test retrieval of the current call status when it is idle*/
-	TInt ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
-
-	RMobileCall::TMobileCallStatus mobileLineStatus;
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-031.01")) ;
-
-	INFO_PRINTF1(_L("Please ring the phone"));
-
-	/* @test GT83-AT-024	Test setting notification of an incoming call on a Voice Line */
-	iLine.NotifyIncomingCall(iStatus, callName);	// wait for a call
-	TESTL(CallMeDear() == KErrNone) ;		// AMC - Added
-	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.02")) ;
-	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
-
-	/* @test GT83-AT-36	Test retrieval of the current call status when it is ringing*/
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusRinging, _L("GT83-TVOICE-004.04")) ;
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusRinging, _L("GT83-TVOICE-030.003")) ;
-
-	INFO_PRINTF1(_L("Phone is ringing..."));
-	//Test for incomming Voice Call
-	TestLineCapabilitiesL();
-
-	/* @test GT83-AT-028	Test opening a new call by specifying the name of a line
-	*/
-	ret = iVoiceCall.OpenExistingCall(iLine, callName);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
-
-	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
-	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
-	iVoiceCall.AnswerIncomingCall(iStatus);
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 2 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.04")) ;
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-030.03")) ;
-	TestLineCapabilitiesL();
-
-	/* @test GT83-AT-36	Test retrieval of the current call status when it is connected*/
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.07")) ;
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-030.07")) ;
-
-
-	INFO_PRINTF1(_L("Please stay connected... the test will hang up shortly"));
-	User::After(10*KOneSecond);
-
-	INFO_PRINTF1(_L("Hanging Up"));
-	iVoiceCall.HangUp(iStatus);
-
-	/* @test GT83-AT-36	Test retrieval of the current call status when it is hang up*/
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-004.08")) ;
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-034.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusDisconnecting, _L("GT83-TVOICE-034.09")) ;
-
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;  //???  line 825
-
-	/* @test GT83-AT-36	Test retrieval of the current call status when it is idle*/
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-030.02")) ;
-
-	/* @test GT83-AT-36	Test retrieval of the current call status when it is idle*/
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.02")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-CTestLineNotificationsIncommingCall::CTestLineNotificationsIncommingCall()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestLineNotificationsIncommingCall"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestLineNotificationsIncommingCall::doTestStepL()
-/** Tests line notifications
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-008.02 Test for a notification when there is an incoming call on a voice line
- * @test GT83-TVOICE-009.01 Test setting notification of a change in hook status of a voice line
- * @test GT83-TVOICE-009.02 "Test notification of a change in hook status of a voice line from ""off"" to ""on"""
- * @test GT83-TVOICE-009.03 "Test notification of a change in hook status of a voice line from ""on"" to off"""
- * @test GT83-TVOICE-010.01 "Test notification of a change in the status of the voice line from ""idle"" to ""ringing"" to ""answering"" to ""connected"" to ""hanging up"" to ""idle""
- * @test GT83-TVOICE-011.02 Test notification of a call being added to a voice line that currently has no calls
- * @test GT83-TVOICE-015.05 Test opening an existing call from a voice line by specifying the name of the line and the name of an existing call
- * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
- * @test GT83-TVOICE-031.01 Test setting a request for a notification of a change in the status of the mobile voice line
- * @test GT83-TVOICE-031.07 "Test for a notification of a change in status of the mobile voice line from ""connected"" to ""disconnecting"""
- * @test GT83-TVOICE-031.08 "Test for a notification of a change in status of the mobile voice line from ""disconnecting"" to ""idle"""
- * @test GT83-TVOICE-031.09 "Test for a notification of a change in status of the mobile voice line from ""idle"" to ""ringing"""
- * @test GT83-TVOICE-031.10 "Test for a notification of a change in status of the mobile voice line from ""ringing"" to ""answering"""
- * @test GT83-TVOICE-031.11 "Test for a notification of a change in status of the mobile voice line from ""answering"" to ""connected"""
-*/
-{
-	INFO_PRINTF1(_L("Test Line Notifications"));
-	TBuf<16> GoodNumber ;
-	GetGoodNumber(GoodNumber) ;
-
-	// NotifyIncomingCall and NotifyStatusChange
-	TName callName1;
-	TName callName2;
-	TInt ret = KErrNone;
-	RCall::TStatus lineStatus;
-	RMobileCall::TMobileCallStatus mobileLineStatus;
-	RCall::THookStatus hookStatus;
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	INFO_PRINTF1(_L("Please ring the phone"));
-
-	iLine.NotifyIncomingCall(iStatus, callName1);	// wait for a call
-
-	//GT83-AT-026	Test setting notification of a change in the status of the Voice Line
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-
-	//GT83-AT-037	Test setting notification of a change in hook status of a Voice Line	void RLine::NotifyHookChange(TRequestStatus& aStatus, THookStatus& aHookStatus)	Function does not produce any unexpected errors. aStatus = KErrPending
-	iLine.NotifyHookChange(iStatus4, hookStatus);
-
-    /* GT83-AT-025	Test notification of a call being added to a Voice Line 	*/
-	iLine.NotifyCallAdded(iStatus5, callName2);
-
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-008.02")) ;
-	CHECKPOINT(iStatus2.Int(), KRequestPending, _L("GT83-TVOICE-010.01")) ;
-	CHECKPOINT(iStatus3.Int(), KRequestPending, _L("GT83-TVOICE-031.01")) ;
-	CHECKPOINT(iStatus4.Int(), KRequestPending, _L("GT83-TVOICE-009.01")) ;
-	CHECKPOINT(iStatus5.Int(), KRequestPending, _L("GT83-TVOICE-0011.01")) ;
-
-	TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
-
-	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.02")) ;
-
-    // @test GT83-AT-026	Test notification of a change in the status of the Voice Line
-	// from "idle" to "ringing"
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.02")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusRinging, _L("GT83-TVOICE-010.02")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.09")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusRinging, _L("GT83-TVOICE-031.09")) ;
-
-	/* GT83-AT-025	Test notification of a call being added to a Voice Line
-	that currently has no calls*/
-	User::WaitForRequest(iStatus5);
-	CHECKPOINT(iStatus5.Int(), KErrNone, _L("GT83-TVOICE-011.02")) ;
-	CHECKPOINT(callName2 == callName1, 1,  _L("GT83-TVOICE-011.02")) ;
-
-	INFO_PRINTF1(_L("Phone is ringing... Now answering..."));
-
-	/* @test GT83-AT-026	Test notification of a change in the status of the Voice Line from
-	 "idle" to "ringing" to "answering" to "connected" to "hanging up" to "idle"
-	 */
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-
-	ret = iVoiceCall.OpenExistingCall(iLine, callName1);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
-
-	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
-	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
-	iVoiceCall.AnswerIncomingCall(iStatus);
-
-    // GT83-AT-026	Test notification of a change in the status of the Voice Line
-	// from "ringing" to "answering"
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.01")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusAnswering, _L("GT83-TVOICE-010.01")) ;
-
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 2 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;	  //wrong code -1632960000
-
-
-    // @test GT83-AT-026	Test notification of a change in the status of the Voice Line
-	// from "answering"	to "connecting"
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.01")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-010.01")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.10")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusAnswering, _L("GT83-TVOICE-031.10")) ;
-
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.11")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.11")) ;
-
-	User::WaitForRequest(iStatus4);
-	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-009.02")) ;
-	CHECKPOINT(hookStatus, RCall::EHookStatusOff, _L("GT83-TVOICE-009.02")) ;
-
-	// now hangup call
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-	iLine.NotifyHookChange(iStatus4, hookStatus);
-
-	INFO_PRINTF1(_L("Call connected - now hanging up..."));
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;
-
-    //GT83-AT-026	Test notification of a change in the status of the Voice Line
-	// from "connecting" to "hanging up"
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.02")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-010.02")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.07")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusDisconnecting, _L("GT83-TVOICE-031.07")) ;
-
-	// @test GT83-AT-026	Test notification of a change in the status of the data
-	// line from "hanging up" to "idle"
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.02")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-010.02")) ;
-
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.08")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-031.08")) ;
-
-	//!< @test GT83-AT-037	Test notification of a change in hook status of a Voice Line
-	//!<  from "off" to "on" aHookStatus = EHookStatusOff before the hook status changes,
-	//!< and EHookStatusOn after the hook status changes
-	User::WaitForRequest(iStatus4);
-	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-009.03")) ;
-	CHECKPOINT(hookStatus, RCall::EHookStatusOn, _L("GT83-TVOICE-009.03")) ;
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestCallNotificationsIncommingCall::CTestCallNotificationsIncommingCall()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestCallNotificationsIncommingCall"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestCallNotificationsIncommingCall::doTestStepL()
-/**
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-002.00 Test retrieval of a voice line's capabilities (Generic)
- * @test GT83-TVOICE-008.01 Test setting notification of an incoming call on a voice line
- * @test GT83-TVOICE-015.05 Test opening an existing call from a voice line by specifying the name of the line and the name of an existing call
- * @test GT83-TVOICE-016.04 "Test retrieval of the current call status when the call's status is ""ringing"""
- * @test GT83-TVOICE-016.05 "Test retrieval of the current call status when the call's status is ""answering"""
- * @test GT83-TVOICE-018.01 Test setting notification of a change in the call's capabilities
- * @test GT83-TVOICE-018.02 Test notification of a change in the call's capabilities as the call's state changes (eg. From idle to connected). Print the call's capabilities to screen
- * @test GT83-TVOICE-020.01 Test setting notification of a change in hook status of a voice call
- * @test GT83-TVOICE-020.02 "Test notification of a change in hook status of a voice call from ""off"" to ""on"""
- * @test GT83-TVOICE-020.03 "Test notification of a change in hook status of a voice call from ""on"" to off"""
- * @test GT83-TVOICE-021.01 Test setting notification of a change in the status of the voice call
- * @test GT83-TVOICE-021.02 "Test notification of a change in the status of the voice call from ""idle"" to ""ringing"" to ""answering"" to ""connected"" to ""hanging up"" to ""idle""
- * @test GT83-TVOICE-022.01 Test setting notification of a change in the voice call's duration
- * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
- * @test GT83-TVOICE-033.01 Test setting notification of a change in the call's dynamic call control and call event capabilities
- * @test GT83-TVOICE-033.02 Test notification of a change in the call's dynamic call control and call event capabilities. Print the call's capabilities to screen
- * @test GT83-TVOICE-034.04 "Test retrieval of the current status of the voice call when the call's status is ""ringing"""
- * @test GT83-TVOICE-035.01 Test setting a request for a notification of a change in the status of the mobile voice call
- * @test GT83-TVOICE-035.07 "Test for a notification of a change in status of the mobile voice call from ""connected"" to ""disconnecting"""
- * @test GT83-TVOICE-035.08 "Test for a notification of a change in status of the mobile voice call from ""disconnecting"" to ""idle"""
- * @test GT83-TVOICE-035.10 "Test for a notification of a change in status of the mobile voice call from ""ringing"" to ""answering"""
- * @test GT83-TVOICE-035.11 "Test for a notification of a change in status of the mobile voice call from ""answering"" to ""connected"""
-*/
-	{
-	// Post call status change notifications
-	TName callName1;
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	RCall::TStatus callStatus;
-	RMobileCall::TMobileCallStatus mobileCallStatus;
-
-	RCall::TCaps caps;
-	RCall::THookStatus hookStatus;
-	TTimeIntervalSeconds time;
-
-	RMobileCall::TMobileCallCapsV1 mobileCallCaps;
-	RMobileCall::TMobileCallCapsV1Pckg mobileCallCapsPckg(mobileCallCaps);
-
-	INFO_PRINTF1(_L("Test Call Notifications"));
-	// Open a Voice Line and Call
-	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	INFO_PRINTF1(_L("Please ring the phone"));
-
-	iLine.NotifyIncomingCall(iStatus, callName1);	// wait for a call
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-008.01")) ;
-
-
-    TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
-
-
-	WaitWithTimeout(iStatus,60*KOneSecond);				// but timeout after 60 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.01")) ;
-
-	TInt ret = iVoiceCall.OpenExistingCall(iLine, callName1);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
-
-	iVoiceCall.GetStatus(callStatus);
-	CHECKPOINT(callStatus, RCall::EStatusRinging, _L("GT83-TVOICE-016.04")) ;
-
-	iVoiceCall.GetMobileCallStatus(mobileCallStatus);
-	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusRinging, _L("GT83-TVOICE-034.04")) ;
-
-	ret=iVoiceCall.GetCaps(caps);
-	Print_TCapsEnum(caps) ;
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-002.00")) ;
-	TESTL((caps.iFlags & (RCall::KCapsVoice | RCall::KCapsAnswer)));
-
-//	INFO_PRINTF1(_L("Opening New Voice Call"));
-//	CHECKPOINT(iiVoiceCall.OpenExistingCall(iLine, callName2), KErrNone, _L("GT83-TVOICE-013.06")) ;
-
-	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
-	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
-#ifndef SIM_TSY
-	iVoiceCall.NotifyCapsChange(iStatus4, caps);
-#endif
-	iVoiceCall.NotifyHookChange(iStatus5, hookStatus);
-	iVoiceCall.NotifyCallDurationChange(iStatus6, time) ;
-	iVoiceCall.NotifyMobileCallCapsChange(iStatus7, mobileCallCapsPckg);
-
-	INFO_PRINTF1(_L("Phone is ringing... Now answering..."));
-	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
-	iVoiceCall.AnswerIncomingCall(iStatus);
-
-	//doesn't work for MM.TSY iVoiceCall.GetStatus(callStatus);
-	//CHECKPOINT(callStatus, RCall::EStatusAnswering, _L("GT83-TVOICE-016.05")) ;
-
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 2 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
-
-
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
-	CHECKPOINT(callStatus, RCall::EStatusAnswering, _L("GT83-TVOICE-021.02")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.01")) ;
-	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusAnswering, _L("GT83-TVOICE-035.10")) ;
-
-	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.01")) ;
-	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-035.11")) ;
-
-#ifndef SIM_TSY
-	User::WaitForRequest(iStatus4);
-	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-018.01")) ;
-	Print_TCapsEnum(caps) ;
-	CHECKPOINT(caps.iFlags, RCall::KCapsVoice, _L("GT83-TVOICE-018.02")) ;
-
-	iVoiceCall.NotifyCapsChange(iStatus4, caps);
-	User::WaitForRequest(iStatus4);
-	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-018.01")) ;
-	CHECKPOINT(caps.iFlags, (RCall::KCapsVoice | RCall::KCapsHangUp), _L("GT83-TVOICE-018.01")) ;
-#endif
-
-	User::WaitForRequest(iStatus5);
-	CHECKPOINT(iStatus5.Int(), KErrNone, _L("GT83-TVOICE-020.01")) ;
-	CHECKPOINT(hookStatus, RCall::EHookStatusOff, _L("GT83-TVOICE-020.03")) ;
-
-	User::WaitForRequest(iStatus6);
-
-#ifndef SIM_TSY
-	CHECKPOINT(iStatus6.Int(), KErrNone, _L("GT83-TVOICE-022.01")) ;
-#endif
-
-	if (iStatus6==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Notify Call Duration Change is NOT Supported"));
-		}
-	if (iStatus6==KErrNone)
-		{
-		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), time.Int());
-		}
-
-	User::WaitForRequest(iStatus7);
-#ifndef SIM_TSY
-	CHECKPOINT(iStatus7.Int(), KErrNone, _L("GT83-TVOICE-033.01")) ;
-	CHECKPOINT(mobileCallCaps.iCallControlCaps, RCall::KCapsVoice, _L("GT83-TVOICE-033.02")) ;
-#endif
-
-#ifndef SIM_TSY //MAY hang the app.
-	iVoiceCall.NotifyMobileCallCapsChange(iStatus7, mobileCallCapsPckg);
-	User::WaitForRequest(iStatus7);
-	CHECKPOINT(iStatus7.Int(), KErrNone, _L("GT83-TVOICE-033.01")) ;
-	CHECKPOINT(mobileCallCaps.iCallControlCaps, (RCall::KCapsVoice | RCall::KCapsHangUp), _L("GT83-TVOICE-033.02")) ;
-#endif
-
-	// now hangup call
-	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
-	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
-
-	INFO_PRINTF1(_L("Call connected - now hanging up..."));
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-020.01")) ;	//sometimes timed out -33
-
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
-	CHECKPOINT(callStatus, RCall::EStatusConnected, _L("GT83-TVOICE-021.02")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.07")) ;
-	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusDisconnecting, _L("GT83-TVOICE-035.07")) ;
-
-	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
-	CHECKPOINT(callStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-021.02")) ;
-
-	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.01")) ;
-	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-035.08")) ;
-
-	TESTL(iStatus == KErrNone) ;
-	TESTL(iStatus2 == KErrNone) ;
-	TESTL(iStatus3 == KErrNone) ;
-	TESTL(iStatus4 == KErrNone) ;
-	TESTL(iStatus5 == KErrNone) ;
-#ifndef SIM_TSY
-	TESTL(iStatus6 == KErrNone) ;
-	TESTL(iStatus7 == KErrNone) ;
-#endif
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestCallNotificationsOutgoingCall::CTestCallNotificationsOutgoingCall()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestCallNotificationsOutgoingCall"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestCallNotificationsOutgoingCall::doTestStepL()
-/**
- @test GT83-TVOICE-016.08	Test retrieval of the current call status when the call's status is "hanging up"
-*/
-	{
-	// Post call status change notifications
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-    TName CallName ;
-
-	RCall::TStatus callStatus;
-	RMobileCall::TMobileCallStatus mobileCallStatus;
-
-	//TTimeIntervalSeconds time;
- 	//RMobileCall::TMobileCallCapsV1 mobileCallCaps;
-	//RMobileCall::TMobileCallCapsV1Pckg mobileCallCapsPckg(mobileCallCaps);
-
-	TBuf<16> GoodNumber ;
-	GetGoodNumber(GoodNumber) ;
-
-	INFO_PRINTF1(_L("Test Call Notifications"));
-	// Open a Voice Line and Call
-	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
-
-	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
-	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
-
-	// Now test call status during an outgoing call
-	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
-	iVoiceCall.Dial(iStatus, GoodNumber);
-
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
-	CHECKPOINT(callStatus, RCall::EStatusDialling, _L("GT83-TVOICE-021.03")) ;
-	iVoiceCall.GetStatus(callStatus) ;
-	CHECKPOINT(callStatus, RCall::EStatusDialling, _L("GT83-TVOICE-016.03")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.01")) ;
-	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusDialling, _L("GT83-TVOICE-035.02")) ;
-	iVoiceCall.GetMobileCallStatus(mobileCallStatus) ;
-	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusDialling, _L("GT83-TVOICE-034.03")) ;
-
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 60 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
-
-	// now hangup call
-	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
-	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
-
-	INFO_PRINTF1(_L("Call connected - now hanging up..."));
-	iVoiceCall.HangUp(iStatus);
-
-	//doesn't work for MM.TSY
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
-	//CHECKPOINT(callStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-021.03")) ;
-
-	User::WaitForRequest(iStatus3);
-	iVoiceCall.GetMobileCallStatus(mobileCallStatus) ;
-	TEST_CHECKL(mobileCallStatus, RMobileCall::EStatusHangingUp, _L("GT83-TVOICE-016.08")) ;
-
-
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-020.01")) ;	//sometimes timed out -33
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestLineNotificationsOutgoingCall::CTestLineNotificationsOutgoingCall()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestLineNotificationsOutgoingCall"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestLineNotificationsOutgoingCall::doTestStepL()
-/** Tests line notifications
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-009.02 "Test notification of a change in hook status of a voice line from ""off"" to ""on"""
- * @test GT83-TVOICE-009.03 "Test notification of a change in hook status of a voice line from ""on"" to off"""
- * @test GT83-TVOICE-010.03 "Test notification of a change in the status of the voice line from ""idle"" to ""dialling"" to ""connecting"" to ""connected"" to ""hanging up"" to ""idle""
- * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
- * @test GT83-TVOICE-031.02 "Test for a notification of a change in status of the mobile voice line from ""idle"" to ""dialling"""
- * @test GT83-TVOICE-031.04 "Test for a notification of a change in status of the mobile voice line from ""connecting"" to ""connected"""
- * @test GT83-TVOICE-031.07 "Test for a notification of a change in status of the mobile voice line from ""connected"" to ""disconnecting"""
- * @test GT83-TVOICE-031.08 "Test for a notification of a change in status of the mobile voice line from ""disconnecting"" to ""idle"""
-*/
-	{
-	INFO_PRINTF1(_L("Test Line Notifications"));
-	TBuf<16> GoodNumber ;
-	GetGoodNumber(GoodNumber) ;
-
-	// NotifyIncomingCall and NotifyStatusChange
-	TName callName1;
-	//TName callName2;
-	//TInt ret = KErrNone;
-	RCall::TStatus lineStatus;
-	RMobileCall::TMobileCallStatus mobileLineStatus;
-	RCall::THookStatus hookStatus;
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, callName1), KErrNone, _L("GT83-TVOICE-014.05"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &callName1);
-
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-	iLine.NotifyHookChange(iStatus4, hookStatus);
-
-	// Now test call status during an outgoing call
-	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
-	iVoiceCall.Dial(iStatus, GoodNumber);
-
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusDialling, _L("GT83-TVOICE-010.03")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.02")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusDialling, _L("GT83-TVOICE-031.02")) ;
-
-	User::WaitForRequest(iStatus4);
-	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-009.03")) ;
-	CHECKPOINT(hookStatus, RCall::EHookStatusOff, _L("GT83-TVOICE-009.03")) ;
-
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-	iLine.NotifyHookChange(iStatus4, hookStatus);
-
-#ifdef SIM_TSY //It has connecting status
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusConnecting, _L("GT83-TVOICE-010.03")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.03")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnecting, _L("GT83-TVOICE-031.03")) ;
-
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-#endif
-
-	User::WaitForRequest(iStatus); //end of dial
-
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-010.03")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.04")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.04")) ;
-
-	INFO_PRINTF1(_L("Call connected - hanging up..."));
-
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-
-	User::After(10*KOneSecond);
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;
-
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-010.03")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.07")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusDisconnecting, _L("GT83-TVOICE-031.07")) ;
-
-	/* @test GT83-AT-037	Test notification of a change in hook status of a data
-	 line from "on" to off"	aHookStatus = EHookStatusOn before the hook status changes,
-	 */
-	User::WaitForRequest(iStatus4);
-	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-009.02")) ;
-	CHECKPOINT(hookStatus, RCall::EHookStatusOn, _L("GT83-TVOICE-009.02")) ;
-
-	iLine.NotifyStatusChange(iStatus2, lineStatus);
-	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
-
-	User::WaitForRequest(iStatus2);
-	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-010.03")) ;
-
-	User::WaitForRequest(iStatus3);
-	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.08")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-031.08")) ;
-
-	TESTL(iStatus == KErrNone) ;
-	TESTL(iStatus2 == KErrNone) ;
-	TESTL(iStatus3 == KErrNone) ;
-	TESTL(iStatus4 == KErrNone) ;
-	TESTL(iStatus5 == KErrNone) ;
-#ifndef SIM_TSY
-	TESTL(iStatus6 == KErrNone) ;
-	TESTL(iStatus7 == KErrNone) ;
-#endif
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestLineStatusOutgoingCall::CTestLineStatusOutgoingCall()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestLineStatusOutgoingCall"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestLineStatusOutgoingCall::doTestStepL()
-/**	 Tests line status function
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-004.00 Test retrieval of a voice line's current status (Generic)
- * @test GT83-TVOICE-004.01 "Test retrieval of a voice line's current status when the line's status is ""Unknown"""
- * @test GT83-TVOICE-004.02 "Test retrieval of a voice line's current status when the line's status is ""Idle"""
- * @test GT83-TVOICE-004.03 "Test retrieval of a voice line's current status when the line's status is ""Dialling"""
- * @test GT83-TVOICE-004.07 "Test retrieval of a voice line's current status when the line's status is ""Connected"""
- * @test GT83-TVOICE-004.08 "Test retrieval of a voice line's current status when the line's status is ""Hanging up"""
- * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
- * @test GT83-TVOICE-030.00 Test retrieval of a mobile voice line's current status (Generic)
- * @test GT83-TVOICE-030.07 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""on hold"""
- * @test GT83-TVOICE-031.01 Test setting a request for a notification of a change in the status of the mobile voice line
-*/
-	{
-	INFO_PRINTF1(_L("Test Line Status"));
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	RCall::TStatus lineStatus;
-    TName CallName ;
-	TBuf<16> GoodNumber ;
-	GetGoodNumber(GoodNumber) ;
-	// Open a Voice Line and Call
-	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	/* @test GT83-AT-36	Test retrieval of the current call status when it is idle*/
-	TInt ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
-
-	RMobileCall::TMobileCallStatus mobileLineStatus;
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-031.01")) ;
-	/* @test GT83-AT-028	Test opening a new call by specifying the name of a line
-	*/
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
-
-	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
-	iVoiceCall.Dial(iStatus, GoodNumber);
-
-	//doesn't work for MM.TSY
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	//CHECKPOINT(lineStatus, RCall::EStatusDialling, _L("GT83-TVOICE-004.03")) ;
-
-	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;
-	//Test for outgoing Voice Call
-	TestLineCapabilitiesL();
-
-	/* @test GT83-AT-36	Test retrieval of the current call status when it is connected*/
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.07")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.07")) ;
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-030.07")) ;
-
-
-	INFO_PRINTF1(_L("Please stay connected... the test will hang up shortly"));
-	User::After(10*KOneSecond);
-
-	INFO_PRINTF1(_L("Call connected - listen for 20 seconds..."));
-
-	User::After(20*KOneSecond); // hold call active for 20 seconds
-
-	INFO_PRINTF1(_L("Hanging up"));
-	iVoiceCall.HangUp(iStatus);
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-004.08")) ;
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;
-
-	//Test for outgoing Voice Call after hang up
-	TestLineCapabilitiesL();
-	/* @test GT83-AT-36	Test retrieval of the current call status when it is connected*/
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-004.01")) ;
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestCallStatusOutgoingCall::CTestCallStatusOutgoingCall()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestCallStatusOutgoingCall"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestCallStatusOutgoingCall::doTestStepL()
-/**
- * This function tests call status at various times during calls
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-009.01 Test setting notification of a change in hook status of a voice line
- * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
- * @test GT83-TVOICE-016.00 Test retrieval of the current call status (Generic)
- * @test GT83-TVOICE-016.02 "Test retrieval of the current call status when the call's status is ""idle"""
- * @test GT83-TVOICE-016.07 "Test retrieval of the current call status when the call's status is ""connected"""
- * @test GT83-TVOICE-025.00 Test dialling a voice call (Generic)
- * @test GT83-TVOICE-034.00 Test retrieval of the current status of the voice call (Generic)
- * @test GT83-TVOICE-034.02 "Test retrieval of the current status of the voice call when the call's status is ""idle"""
- * @test GT83-TVOICE-034.07 "Test retrieval of the current status of the voice call when the call's status is ""connected"""
-*/
-	{
-	// Get the Call Status
-	INFO_PRINTF1(_L("Get Call Status..."));
-	// Open a Voice Line and Call
-	INFO_PRINTF1(_L("Opening Voice Line"));
-
-	RCall::TStatus callStatus;
-	RMobileCall::TMobileCallStatus mobileCallStatus;
-    TName CallName ;
-
-	TBuf<16> GoodNumber ;
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	GetGoodNumber(GoodNumber) ;
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
-
-
-	TInt ret=iVoiceCall.GetStatus(callStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
-	TInt ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
-	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
-
-	if (ret==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Call Status is NOT Supported"));
-		}
-
-	if (ret2==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Mobile Call Status is NOT Supported"));
-		}
-
-	if ((ret==KErrNone) && (ret2==KErrNone))
-		{
-		CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.02")) ;
-		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.02")) ;
-		INFO_PRINTF1(_L("The call is Idle"));
-		}
-
-	// Now test call status during an outgoing call
-
-	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
-	iVoiceCall.Dial(iStatus, GoodNumber);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-025.00")) ;
-
-	ret=iVoiceCall.GetStatus(callStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
-	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
-	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
-
-	if ((ret==KErrNone) && (ret2==KErrNone))
-		{
-
-		Print_RCall_TStatus(callStatus) ;
-		CHECKPOINT(callStatus, RCall::EStatusConnected, _L("GT83-TVOICE-016.07")) ;
-		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-034.07")) ;
-		INFO_PRINTF1(_L("The call is Connected"));
-		}
-
-	INFO_PRINTF1(_L("Hanging up..."));
-
-	User::After(15*KOneSecond);
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-009.01")) ;
-
-	ret=iVoiceCall.GetStatus(callStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
-	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
-	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
-
-	if ((ret==KErrNone) && (ret2==KErrNone))
-		{
-		CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.02")) ;
-		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.02")) ;
-		INFO_PRINTF1(_L("The call is Idle again"));
-		}
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestCallStatusIncommingCall::CTestCallStatusIncommingCall()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestCallStatusIncommingCall"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestCallStatusIncommingCall::doTestStepL()
-/**
- * This function tests call status at various times during calls
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-009.01 Test setting notification of a change in hook status of a voice line
- * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
- * @test GT83-TVOICE-016.00 Test retrieval of the current call status (Generic)
- * @test GT83-TVOICE-016.02 "Test retrieval of the current call status when the call's status is ""idle"""
- * @test GT83-TVOICE-016.04 "Test retrieval of the current call status when the call's status is ""ringing"""
- * @test GT83-TVOICE-016.05 "Test retrieval of the current call status when the call's status is ""answering"""
- * @test GT83-TVOICE-016.07 "Test retrieval of the current call status when the call's status is ""connected"""
- * @test GT83-TVOICE-034.00 Test retrieval of the current status of the voice call (Generic)
- * @test GT83-TVOICE-034.02 "Test retrieval of the current status of the voice call when the call's status is ""idle"""
- * @test GT83-TVOICE-034.04 "Test retrieval of the current status of the voice call when the call's status is ""ringing"""
- * @test GT83-TVOICE-034.05 "Test retrieval of the current status of the voice call when the call's status is ""answering"""
- * @test GT83-TVOICE-034.07 "Test retrieval of the current status of the voice call when the call's status is ""connected"""
- */
-	{
-	// Get the Call Status
-	INFO_PRINTF1(_L("Get Call Status..."));
-	// Open a Voice Line and Call
-	INFO_PRINTF1(_L("Opening Voice Line"));
-    TName CallName ;
-
-	RCall::TStatus callStatus;
-	RMobileCall::TMobileCallStatus mobileCallStatus;
-	TBuf<16> GoodNumber ;
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	GetGoodNumber(GoodNumber) ;
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
-
-
-	TInt ret=iVoiceCall.GetStatus(callStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
-	TInt ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
-	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
-
-	if (ret==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Call Status is NOT Supported"));
-		}
-
-	if (ret2==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Mobile Call Status is NOT Supported"));
-		}
-
-	if ((ret==KErrNone) && (ret2==KErrNone))
-		{
-		CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.02")) ;
-		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.02")) ;
-		INFO_PRINTF1(_L("The call is Idle"));
-		}
-
-	// Now test call status during an incomming call
-
-	// Wait for an incoming call, then get the Call BearerServiceInfo. The
-	// Bearer Service Info is only available if the call is currently active
-	INFO_PRINTF1(_L("Please ring the phone "));
-
-    TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
-	//User::After(1000000L);
-
-
-	/* GT83-AT-024	Test setting notification of an incoming call on a Voice Line */
-
-	//I had to comment these lines, because
-	// NotifyIncommigCall + AnswerIncommigCall doesn't work
-	//in such situation. Any way we can't get any good
-	//status without notifycation
-
-	//iLine.NotifyIncomingCall(iStatus, CallName);	// wait for a call
-	//WaitWithTimeout(iStatus,60*KOneSecond);				// but timeout after 60 seconds
-
-	//ret=iVoiceCall.GetStatus(callStatus);
-	//CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
-	//doesn't work for MM.TSY
-	//CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.01")) ;
-
-	//ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
-	//CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
-	//doesn't work for MM.TSY
-	//CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.01")) ;
-
-	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
-	iVoiceCall.AnswerIncomingCall(iStatus);
-	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 7 seconds
-
-	ret=iVoiceCall.GetStatus(callStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
-	//doesn't work for MM.TSY
-	//CHECKPOINT(callStatus, RCall::EStatusAnswering, _L("GT83-TVOICE-016.05")) ;
-
-	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
-	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
-	//doesn't work for MM.TSY
-	//CHECKPOINT(mobileCallStatus, RMobileCall::EStatusAnswering, _L("GT83-TVOICE-034.05")) ;
-	
-	ret=iVoiceCall.GetStatus(callStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
-	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
-	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
-
-	if ((ret==KErrNone) && (ret2==KErrNone))
-		{
-
-		Print_RCall_TStatus(callStatus) ;
-		CHECKPOINT(callStatus, RCall::EStatusConnected, _L("GT83-TVOICE-016.07")) ;
-		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-034.07")) ;
-		INFO_PRINTF1(_L("The call is Connected"));
-		}
-	INFO_PRINTF1(_L("Hanging up..."));
-
-	User::After(15*KOneSecond);
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-009.01")) ;
-
-	ret=iVoiceCall.GetStatus(callStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
-	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
-	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
-
-	if ((ret==KErrNone) && (ret2==KErrNone))
-		{
-		CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.02")) ;
-		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.02")) ;
-		INFO_PRINTF1(_L("The call is Idle again"));
-		}
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestLineInfo::CTestLineInfo()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestLineInfo"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestLineInfo::doTestStepL()
-/**
- * This function gets the Line capabilities, line information, Number of calls
- * on the line and call information,
- * @test NONE	Test the ability to get the current line information of the Voice Line (Generic)
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-005.01 "Test retrieval of the current hook status, when the line is currently ""off hook"""
- * @test GT83-TVOICE-005.02 "Test retrieval of the current hook status, when the line is currently ""on hook"""
- * @test GT83-TVOICE-012.01 Test the ability to get the current line information of the voice line. Display the line information to screen.
- * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
- * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
- * @test GT83-TVOICE-027.02 Test the ability to place an asynchronous request to hang up a voice call
- */
-	{
-	INFO_PRINTF1(_L("Test Line Information"));
-	// Open a Voice Line and Call
-	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
-	TInt ret ;
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-    TName CallName ;
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
-
-	// Line Information
-	RLine::TLineInfo lineInfo;
-	TRAP(ret, ret=iLine.GetInfo(lineInfo));
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-012.01"));
-	if (ret!=KErrNone)
-		{
-		INFO_PRINTF1(_L("Get Line Info. is NOT supported"));
-		}
-	else
-		{
-		INFO_PRINTF1(_L("Get Line Info is successful"));
-		CHECKPOINT(lineInfo.iHookStatus,  RCall::EHookStatusOn, _L("GT83-TVOICE-0AAA")) ;
-		TESTL(lineInfo.iStatus == RCall::EStatusIdle) ;
-		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Name of last call added: %S")), &lineInfo.iNameOfLastCallAdded);
-		}
-
-	// Hook status information
-	INFO_PRINTF1(_L("Retrieving Hook Status..."));
-	RCall::THookStatus hookStatus;
-	ret=iLine.GetHookStatus(hookStatus);
-	if (ret!=KErrNone)
-		{
-		INFO_PRINTF1(_L("Get Hook status is NOT supported"));
-		}
-	else
-		{
-		CHECKPOINT(hookStatus, RCall::EHookStatusOn, _L("GT83-TVOICE-005.02")) ;
-		INFO_PRINTF1(_L("The line is currently ON Hook"));
-		}
-
-	INFO_PRINTF1(_L("Please ring the phone"));
-
-    TESTL(CallMeDear() == KErrNone) ; //init sim incoming call
-
-
-	// Answer an incoming call initiated  and obtain the call's current status
-	iVoiceCall.AnswerIncomingCall(iStatus);
-
-	WaitWithTimeout(iStatus,2*KTenSeconds);		// but timeout after 60 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
-
-	// Count the no. of calls on the line & Get call info.
-	INFO_PRINTF1(_L("Retrieving no. of calls opened from the line.."));
-	TInt lineCount=0;
-	iLine.EnumerateCall(lineCount);
-	INFO_PRINTF2(TRefByValue<const TDesC>(_L("No of calls opened = %d")), lineCount);
-
-	//doesn't work for MM.TSY
-	INFO_PRINTF1(_L("Getting Call info.."));
-	RLine::TCallInfo callInfo;
-	ret=iLine.GetCallInfo(0,callInfo);
-	//doesn't work for MM.TSY
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-007.01"));
-
-	if (ret==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Call information is NOT supported"));
-		}
-	if (ret==KErrNone)
-		{
-		INFO_PRINTF1(_L("Get Call information is successful"));
-		}
-
-	// Get the line's current hook status
-	ret=iLine.GetHookStatus(hookStatus);
-	if (ret!=KErrNone)
-		{
-		INFO_PRINTF1(_L("Get Hook status is NOT supported"));
-		}
-	else
-		{
-		CHECKPOINT(hookStatus, RCall::EHookStatusOff, _L("GT83-TVOICE-005.01")) ;
-		INFO_PRINTF1(_L("The line is currently OFF Hook"));
-		}
-
-	INFO_PRINTF1(_L("Please stay connected... the test will hang up shortly"));
-	User::After(KTenSeconds);
-
-	INFO_PRINTF1(_L("Hanging up"));
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-027.02")) ;
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestCallCancels::CTestCallCancels()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestCallCancels"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestCallCancels::doTestStepL()
-/**
- * This function posts and then cancels Call Notifications.
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
- * @test GT83-TVOICE-018.01 Test setting notification of a change in the call's capabilities
- * @test GT83-TVOICE-018.03 Test the ability to cancel a notification of a change in the call's capabilities
- * @test GT83-TVOICE-020.01 Test setting notification of a change in hook status of a voice call
- * @test GT83-TVOICE-020.04 Test the ability to cancel a notification of a change in hook status of a voice call
- * @test GT83-TVOICE-021.01 Test setting notification of a change in the status of the voice call
- * @test GT83-TVOICE-022.01 Test setting notification of a change in the voice call's duration
- * @test GT83-TVOICE-022.03 Test cancelling notification of a change in the voice call's duration
-*/
-	{
-	INFO_PRINTF1(_L("Test Call Cancels"));
-	// Open a Voice Line and Call
-	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-    TName CallName ;
-    INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
-
-	// Call Status Change Cancel Request
-	RCall::TStatus callStatus;
-	iVoiceCall.NotifyStatusChange(iStatus, callStatus);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-021.01")) ;
-	User::After(KTenPartOfSec); //snack some sleep
-	iVoiceCall.NotifyStatusChangeCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-021.04")) ;
-
-#if 0  //cancel functions don't work yet (?)
-	   //any way they are not declared 27.09.2001
-	RMobileCall::TMobileCallStatus mobileCallStatus;
-	iiVoiceCall.NotifyMobileCallStatusChange(iStatus, mobileCallStatus);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-0AAA")) ;
-	iiVoiceCall.NotifyMobileCallStatusChangeCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-0AAA")) ;
-#endif
-	// Hook Change Cancel Request
-	RCall::THookStatus hookStatus;
-	iVoiceCall.NotifyHookChange(iStatus, hookStatus);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-020.01")) ;
-	User::After(KTenPartOfSec); //snack some sleep
-	iVoiceCall.NotifyHookChangeCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-020.04")) ;
-
-	// Test Cancelling Notifications
-	RCall::TCaps callCaps;
-	iVoiceCall.NotifyCapsChange(iStatus, callCaps);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-018.01")) ;
-	User::After(KTenPartOfSec); //snack some sleep
-	iVoiceCall.NotifyCapsChangeCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-018.03")) ;
-
-#if 0  //cancel functions don't work yet (?)
-	   //any way they are not declared 27.09.2001
-	RMobileCall::TMobileCallCapsV1 mobileCallCaps;
-	RMobileCall::TMobileCallCapsV1Pckg mobileCallCapsPckg(mobileCallCaps);
-	iVoiceCall.NotifyMobileCallCapsChange(iStatus, mobileCallCapsPckg);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-0AAA")) ;
-	iVoiceCall.NotifyMobileCallCapsChangeCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-0AAA")) ;
-
-
-	TTimeIntervalSeconds callDuration;
-	iVoiceCall.NotifyCallDurationChange(iStatus, callDuration);
-	CHECKPOINT((iStatus==KRequestPending || iStatus==KErrNotSupported), 1, _L("GT83-TVOICE-022.01")) ;
-	User::After(KTenPartOfSec); //snack some sleep
-	iVoiceCall.NotifyCallDurationChangeCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNotSupported, _L("GT83-TVOICE-022.03")) ;		// AMC - the SIM TSY does not support duration notifications...
-#endif
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestLineCancels::CTestLineCancels()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestLineCancels"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestLineCancels::doTestStepL()
-/**
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-008.01 Test setting notification of an incoming call on a voice line
- * @test GT83-TVOICE-008.03 Test the ability to cancel the notification of an incoming call on a voice line
- * @test GT83-TVOICE-009.01 Test setting notification of a change in hook status of a voice line
- * @test GT83-TVOICE-009.04 Test the ability to cancel a notification of a change in hook status of a voice line
- * @test GT83-TVOICE-010.04 Test the ability to cancel the notification of a change in the status of the voice line
- * @test GT83-TVOICE-011.01 Test setting notification of a call being added to a voice line
- * @test GT83-TVOICE-011.05 Test the ability to cancel a notification of a call being added to a voice line
- */
-	{
-	INFO_PRINTF1(_L("Test Line Cancels"));
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	// Notify Incoming Call
-	TName callName;
-	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	iLine.NotifyIncomingCall(iStatus, callName);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-008.01")) ;
-	User::After(KTenPartOfSec); //snack some sleep
-	iLine.NotifyIncomingCallCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-008.03")) ;
-
-	// Notify Status Change
-	RCall::TStatus lineStatus;
-	iLine.NotifyStatusChange(iStatus, lineStatus);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-010.02")) ;
-	User::After(KTenPartOfSec); //snack some sleep
-	iLine.NotifyStatusChangeCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-010.04")) ;
-
-#if 0  //cancel functions don't work yet (?)
-	   //any way they are not declared 27.09.2001
-	// Notify Mobile Status Change
-	RMobileCall::TMobileCallStatus lineStatus2;
-	iLine.NotifyMobileLineStatusChange(iStatus, lineStatus2);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-0AAA")) ;
-	iLine.NotifyMobileLineStatusChangeCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-0AAA")) ;
-#endif
-	// Notify Hook Change
-	RCall::THookStatus hookStatus;
-	iLine.NotifyHookChange(iStatus, hookStatus);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-009.01")) ;
-	User::After(KTenPartOfSec); //snack some sleep
-	iLine.NotifyHookChangeCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-009.04")) ;
-
-	// Notify Call Added
-	iLine.NotifyCallAdded(iStatus, callName);
-	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-011.01")) ;
-	User::After(KTenPartOfSec); //snack some sleep
-	iLine.NotifyCallAddedCancel();
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-011.05")) ;
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestMoreCallInfo::CTestMoreCallInfo()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestMoreCallInfo"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestMoreCallInfo::doTestStepL()
-/**
- * This function gets more information pertaining to a Voice Call: Call ownership,
- * Call parameters, Loan data port requests and Transfer ownership requests.
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
- * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
- * @test GT83-TVOICE-028.01 Test the ability to make a request to acquire the ownership of a call
- * @test GT83-TVOICE-029.01 Test transferring the call ownership when another client has requested to acquire call ownership
- */
-	{
-	INFO_PRINTF1(_L("More Call Information Tests"));
-	TInt ret ;
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-    TName callName;
-	RCall::TStatus lineStatus;
-
-	// my cases I start
-
-	//RCall::TStatus callStatus;	
-	RMobileCall::TMobileCallStatus mobileCallStatus;	
-	TRequestStatus reqStatus0;
-	RMobileCall spareCall;
-	CleanupClosePushL(spareCall);
-
-	// case 1 start
-	iLine.NotifyIncomingCall(iStatus, callName);	// wait for a call
-	TESTL(CallMeDear() == KErrNone) ;		
-	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.02")) ;
-	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
-
-
-	ret = spareCall.OpenExistingCall(iLine, callName);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
-
-	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
-	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
-	spareCall.AnswerIncomingCall(iStatus);
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 2 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.04")) ;
-	spareCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus); 
-	CleanupStack::Pop(&spareCall);
-	spareCall.Close();
-	// case 1 end
-
-	// case 2 start
-	TBuf<16> GoodNumber ;
-	GetGoodNumber(GoodNumber) ;
-
-	RMobileCall voiceCall4;
-	CHECKPOINT(ret=voiceCall4.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-014.05"));
-	voiceCall4.Dial(iStatus,GoodNumber);
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 7 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));	
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.04")) ;
-
-
-	iLine.NotifyIncomingCall(iStatus, callName);	// wait for a call
-
-	TESTL(CallMeDear() == KErrNone); 		// AMC - Added
-	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.02")) ;
-	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusRinging, _L("GT83-TVOICE-004.04")) ;
-
-	ret = spareCall.OpenExistingCall(iLine, callName);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
-	
-	CleanupClosePushL(spareCall);
-	
-	voiceCall4.Hold(iStatus);
-	User::WaitForRequest(iStatus);
-	TEST(iStatus==KErrNone);
-	TEST(voiceCall4.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusHold);
-
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusRinging, _L("GT83-TVOICE-004.04")) ;
-	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
-	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
-	spareCall.AnswerIncomingCall(iStatus);
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 7 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
-	ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.04")) ;
-	spareCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus); 
-	CleanupStack::Pop(&spareCall);
-	spareCall.Close();
-	voiceCall4.Close();
-	// case 2 end
-	// my cases I end
-
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-014.05"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
-
-	// Wait for an incoming Call
-	INFO_PRINTF1(_L("Please ring the phone"));
-
-    iVoiceCall.AnswerIncomingCall(iStatus);		// set as an answering phone
-	TESTL(CallMeDear() == KErrNone)  ;          // init sim incoming call 
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 15 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
-
-	// Retrieve Call Ownership information
-	INFO_PRINTF1(_L("Get Call Ownership.."));
-	RCall::TOwnershipStatus callOwner;
-	ret=iVoiceCall.GetOwnershipStatus(callOwner);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-026.01"));
-
-	if (ret==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Call OwnerShip is NOT Supported"));
-		}
-
-	if (ret==KErrNone)
-		{
-		INFO_PRINTF1(_L("Get Call OwnerShip is Supported"));
-
-		switch(callOwner)
-			{
-			case RCall::EOwnershipUnowned:
-				INFO_PRINTF1(_L("The call is unowned"));
-				break;
-			case RCall::EOwnershipOwnedByAnotherClient:
-				INFO_PRINTF1(_L("The call is owned by another Client"));
-				break;
-			case RCall::EOwnershipOwnedByThisClient:
-				INFO_PRINTF1(_L("The call is owned by this client"));
-				break;
-			default:
-				INFO_PRINTF1(_L("Error in Call Ownership details"));
-				break;
-			}
-		}
-
-	// Call Parameters
-	INFO_PRINTF1(_L("Get Call Parameters..."));
-	RCall::TCallParams callParams;
-	RCall::TCallParamsPckg callParamsPckg(callParams);
-	ret=iVoiceCall.GetCallParams(callParamsPckg);
-#ifndef SIM_TSY
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-0AAA"));
-#endif
-	if (ret==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Call Parameters is NOT Supported"));
-		}
-	if (ret==KErrNone)
-		{
-		INFO_PRINTF1(_L("Get Call Parameters is successful"));
-		}
-	
-	// Post a 'New call added' notification
-	iLine.NotifyCallAdded(iStatus, callName);
-
-	// Open a 2nd Voice Call, see BeginTest() function for explanatory comments
-	INFO_PRINTF1(_L("Opening another Voice Call"));
-	
-	RMobileCall voiceCall2;
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(ret=voiceCall2.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-014.05"));
-	CleanupClosePushL(voiceCall2);
-	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
-
-	if(ret == KErrNone)
-		{
-		INFO_PRINTF1(_L("2nd Voice Call opened successfully"));
-		}
-
-	if(ret == KErrNotSupported) //we don't have anything to do, bye...
-		{
-		User::WaitForRequest(iStatus);  // Notify Call added completion
-
-
-		INFO_PRINTF1(_L("2nd Voice Call are not supported"));
-		INFO_PRINTF1(_L("Hanging up"));
-		iVoiceCall.HangUp(iStatus);
-		User::WaitForRequest(iStatus);
-
-		CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA"));
-		INFO_PRINTF1(_L("HangUp successful"));
-		// Close the line and call
-		CleanupStack::PopAndDestroy(&voiceCall2) ;
-		CleanupStack::PopAndDestroy(&iVoiceCall);
-		CleanupStack::PopAndDestroy(&iLine);
-		return TestStepResult();
-		}
-
-	User::WaitForRequest(iStatus);  // Notify Call added completion
-	if (iStatus==KErrNone)
-		{
-		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Notify Call added status = %d")), iStatus.Int());
-		}
-
-	// my cases II start
-
-
-	// 3rd case put 1st on hold, dial on other
-
-	iVoiceCall.Hold(reqStatus0);
-	User::WaitForRequest(reqStatus0);
-	TEST(reqStatus0==KErrNone);
-	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusHold);
-
-	// Now test call status during an outgoing call
-	
-	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
-	voiceCall2.Dial(iStatus, GoodNumber);			
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 7 seconds
-	TEST(voiceCall2.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
-
-	INFO_PRINTF1(_L("Call connected - now hanging up..."));
-	voiceCall2.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-020.01"));	
-
-
-	iVoiceCall.Resume(reqStatus0);
-	User::WaitForRequest(reqStatus0);
-	TEST(reqStatus0==KErrNone);
-	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
-
-	// 4th case put 1st on hold, answer on other
-
-	iVoiceCall.Hold(reqStatus0);
-	User::WaitForRequest(reqStatus0);
-	TEST(reqStatus0==KErrNone);
-	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusHold);
-
-	RMobileCall::TMobileCallStatus mobileLineStatus;
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusHold, _L("GT83-TVOICE-031.01")) ;
-
-
-	voiceCall2.AnswerIncomingCall(iStatus);		// set as an answering phone
-	TESTL(CallMeDear() == KErrNone)  ;          // init sim incoming call 
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 15 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
-	// now hangup call
-
-	INFO_PRINTF1(_L("Call connected - now hanging up..."));
-	voiceCall2.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusHold, _L("GT83-TVOICE-031.01")) ;
-
-	iVoiceCall.Resume(reqStatus0);
-	User::WaitForRequest(reqStatus0);
-	TEST(reqStatus0==KErrNone);
-	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
-
-
-	// 5th case put 1st on hold, answer on other
-
-	RCall::TCaps callCaps;
- 	ret=iVoiceCall.GetCaps(callCaps);
- 	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
-	TEST(callCaps.iFlags & RCall::KCapsVoice );
-	TEST(callCaps.iFlags & RMobileCall::KCapsHold) ;
-	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
-
-	iVoiceCall.Hold(reqStatus0);
-	User::WaitForRequest(reqStatus0);
-	TEST(reqStatus0==KErrNone);
-	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusHold);	
-
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusHold, _L("GT83-TVOICE-031.01")) ;
-
-
-	iVoiceCall.Swap(reqStatus0);
-	User::WaitForRequest(reqStatus0);
-	TEST(reqStatus0==KErrNone);
-	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
-
-	iVoiceCall.Swap(reqStatus0);
-	User::WaitForRequest(reqStatus0);
-	TEST(reqStatus0==KErrNone);
-	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusHold);
-
-	ret=iVoiceCall.GetCaps(callCaps);
-	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
-	TEST(callCaps.iFlags & RCall::KCapsVoice );
-	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
-	TEST(callCaps.iFlags & RMobileCall::KCapsResume) ;
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusHold, _L("GT83-TVOICE-031.01")) ;
-
-	voiceCall2.AnswerIncomingCall(iStatus);		// set as an answering phone
-	TESTL(CallMeDear() == KErrNone)  ;          // init sim incoming call 
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 15 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
-	TEST(voiceCall2.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
-
-	ret=voiceCall2.GetCaps(callCaps);
-	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
-	TEST(callCaps.iFlags & RCall::KCapsVoice );
-	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
-	TEST(!(callCaps.iFlags & RMobileCall::KCapsHold)) ;
-
-	ret=iVoiceCall.GetCaps(callCaps);
-	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
-	TEST(callCaps.iFlags & RCall::KCapsVoice );
-	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
-	TEST(!(callCaps.iFlags & RMobileCall::KCapsResume)) ;
-	
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
-
-
-	voiceCall2.Swap(iStatus);
-	User::WaitForRequest(iStatus);	
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
-
-	TEST(voiceCall2.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusHold);
-	
-	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
-
-	ret = iLine.GetMobileLineStatus(mobileLineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
-	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
-
-
-	// try to activate call on hold whilst other is connected
-	iVoiceCall.Swap(iStatus);
-	User::WaitForRequest(iStatus);	
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
-
-	TEST(voiceCall2.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
-
-	
-	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
-	TEST(mobileCallStatus==RMobileCall::EStatusHold);
-
-	
-	// try to dial whilst have 2 active
-	
-	RMobileCall voiceCall3;
-	CHECKPOINT(ret=voiceCall3.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-014.05"));
-	CleanupClosePushL(voiceCall3);
-	voiceCall3.Dial(iStatus,GoodNumber);
-	User::WaitForRequest(iStatus);	
-	CHECKPOINT(iStatus.Int(), KErrGeneral, _L("GT83-TVOICE-026.00"));
-	voiceCall3.Close();
-	CleanupStack::Pop(&voiceCall3);
-
-	// try to activate call 
-	iVoiceCall.Swap(iStatus);
-	User::WaitForRequest(iStatus);	
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
-
-	// now hangup call
-
-	INFO_PRINTF1(_L("Call connected - now hanging up..."));
-	ret=iVoiceCall.GetCaps(callCaps);
-	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
-	TEST(callCaps.iFlags & RCall::KCapsVoice );
-	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
-	TEST(!(callCaps.iFlags & RMobileCall::KCapsHold)) ;
-
-	voiceCall2.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-
-	ret=iVoiceCall.GetCaps(callCaps);
-	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
-	TEST(callCaps.iFlags & RCall::KCapsVoice );
-	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
-	TEST(callCaps.iFlags & RMobileCall::KCapsHold) ;
-		
-
-	//Close the 2nd Voice Call
-	voiceCall2.Close();
-	CleanupStack::Pop(&voiceCall2) ;
-	INFO_PRINTF1(_L("Closing the 2nd Voice Call"));
-
-	// my II cases end	
-
-	// Hang up the Call
-	INFO_PRINTF1(_L("Hanging up"));
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-029.02"));
-	INFO_PRINTF1(_L("HangUp successful"));
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestCallInfo::CTestCallInfo()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestCallInfo"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestCallInfo::doTestStepL()
-/**
- * This function gets information pertaining to a call:
- * Bearer Service Information, Call duration, Remote Party Information (if available)
- * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
- * @test GT83-TVOICE-009.02 "Test notification of a change in hook status of a voice line from ""off"" to ""on"""
- * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
- * @test GT83-TVOICE-019.01 "Test retrieval of the bearer service info of a call. Display to screen, all the bearer service information associated with the call."
- * @test GT83-TVOICE-023.01 Test retrieval of the duration of a voice call. Display the call duration to screen
- * @test GT83-TVOICE-024.01 Test the ability to get the current call information of the voice call. Display the call information to screen.
- * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
- * @test GT83-TVOICE-036.01 Test retreival of the call information and print the call information to screen.
-*/
-	{
-	INFO_PRINTF1(_L("Test Call Information"));
-	RMobileCall::TMobileCallInfoV1 mobileCallInfo;
-	RMobileCall::TMobileCallInfoV1Pckg mobileCallInfoPckg(mobileCallInfo) ;
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
-
-	TName CallName ;
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
-
-	//get status
-	RCall::TStatus callStatus;
-	CHECKPOINT(iVoiceCall.GetStatus(callStatus), KErrNone, _L("GT83-TD-016.02")) ;
-	CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TD-016.02")) ;
-
-	INFO_PRINTF2(_L("Call Status = %d"), callStatus);
-	Print_RCall_TStatus(callStatus) ;
-	// Wait for an incoming call, then get the Call BearerServiceInfo. The
-	// Bearer Service Info is only available if the call is currently active
-	INFO_PRINTF1(_L("Please ring the phone"));
-
-    TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
-
-
-	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
-	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
-	iVoiceCall.AnswerIncomingCall(iStatus);
-	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 60 seconds
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
-
-	// User Information
-	INFO_PRINTF1(_L("The call is now connected."));
-	INFO_PRINTF1(_L("Retrieving Call Information."));
-
-	// Bearer Service Information
-	INFO_PRINTF1(_L("Get Bearer Service Info..."));
-	RCall::TBearerService bearerServiceInfo;
-	TInt ret=iVoiceCall.GetBearerServiceInfo(bearerServiceInfo);
-	CHECKPOINT(ret, KErrNotSupported, _L("GT83-TVOICE-019.01")) ;
-	INFO_PRINTF1(_L("Get BearerService Information is NOT Supported"));
-
-	// Get Call Information
-	INFO_PRINTF1(_L("Get Current Call Info..."));
-	ret=iVoiceCall.GetInfo(iCallInfo);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-024.01")) ;
-	if (ret==KErrNone)
-		{
-		INFO_PRINTF1(_L("Displaying Information about the Current Call"));
-		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call name: %S")), &iCallInfo.iCallName);
-		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Line name: %S")), &iCallInfo.iLineName);
-		if (iCallInfo.iHookStatus==RCall::EHookStatusOff)
-			{
-			INFO_PRINTF1(_L("Current Hook Status: Off"));
-			}
-		if (iCallInfo.iStatus==RCall::EStatusConnected)
-			{
-			INFO_PRINTF1(_L("Current Call Status: Connected"));
-			}
-		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call Duration: %d seconds")), iCallInfo.iDuration.Int());
-		}
-
-	INFO_PRINTF1(_L("Get Current Mobile Call Info..."));
-	ret=iVoiceCall.GetMobileCallInfo(mobileCallInfoPckg);
-
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-036.01")) ;
-	if (ret==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Current Call info is NOT Supported"));
-		}
-
-	//Get Remote Party Info (PDEF108459)
- 	RMobileCall::TMobileCallRemotePartyInfoV1 remoteParty;
- 	RMobileCall::TMobileCallRemotePartyInfoV1Pckg remotePartyPckg(remoteParty);	
- 	
- 	TRequestStatus reqStatus;
- 	iVoiceCall.NotifyRemotePartyInfoChange(reqStatus, remotePartyPckg);
- 	User::WaitForRequest(reqStatus);	
- 	
- 	TESTL(reqStatus == KErrNone);
- 	
- 	if (remoteParty.iRemoteIdStatus == RMobileCall::ERemoteIdentityAvailable)
- 		{			
- 		INFO_PRINTF1(_L("Displaying Remote Party Information about the Current Call"));
- 		_LIT(KCallingName, "Calling Name : %S");
- 		INFO_PRINTF2(KCallingName, &remoteParty.iCallingName);
- 		_LIT(KRemoteNumber, "Remote Number : %S");
- 		INFO_PRINTF2(KRemoteNumber, &remoteParty.iRemoteNumber.iTelNumber);
-   		}
-	else
-		{
-		_LIT(KRemoteIdentityNotAvilable,"Remote Identity is not available.");
- 		INFO_PRINTF1(KRemoteIdentityNotAvilable);
-   		}
-
-	// Hang up the Call
-	INFO_PRINTF1(_L("Please stay connected... the test will hang up shortly"));
-	User::After(5*KOneSecond);
-
-	// Call Duration
-	INFO_PRINTF1(_L("Get Call Duration..."));
-	TTimeIntervalSeconds callDuration2;
-	ret=iVoiceCall.GetCallDuration(callDuration2);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-023.01")) ;
-
-	if (ret==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Current Call Duration is NOT Supported"));
-		}
-	if (ret==KErrNone)
-		{
-		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), callDuration2.Int());
-		}
-
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-009.02")) ;
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestPhoneInfo::CTestPhoneInfo()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestPhoneInfo"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestPhoneInfo::doTestStepL()
-/**
- * This function retrieves a snapshot of the phone's GSM information, gets the
- * number of lines associated with the phone as well as information on the line
- * and phone. Gets the phone's status and also performs some Cancel Requests.
- * @test GT83-TVOICE-037.01	Retrieve phone's multimode capabilities and print them to screen.
- */
-	{
-	INFO_PRINTF1(_L("Phone Information test"));
-
-	// Retrieve a snapshot of the current phone information
-	INFO_PRINTF1(_L("Get Phone Info..."));
-	RPhone::TPhoneInfo phoneInfo;
-	RPhone::TCaps phoneCaps;
-	TInt ret=iPhone.GetInfo(phoneInfo);
-	if (ret==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Phone info is NOT Supported"));
-		}
-	if (ret==KErrNone)
-		{
-		INFO_PRINTF1(_L("Get Phone Info is successful."));
-		CHECKPOINT(phoneInfo.iDetection, RPhone::EDetectedPresent, _L("GT83-TVOICE-0AAA"));
-		INFO_PRINTF1(_L("Local Modem has been detected."));
-		}
-
-	//test mobile phone caps
-	RMobilePhone::TMobilePhoneModeCaps mobileCaps ;
-	CHECKPOINT(iPhone.GetMultimodeCaps((TUint32&)mobileCaps), KErrNone, _L("GT83-TVOICE-037.01")) ;
-	Print_TMobilePhoneModeCaps(mobileCaps);
-
-	// Number of lines associated with the phone
-	TInt lineCount=0;
-	TESTL(iPhone.EnumerateLines(lineCount)==KErrNone);
-	TESTL(lineCount>0);
-
-	for (;lineCount>0; lineCount--)
-		{
-		CHECKPOINT(iPhone.GetLineInfo(lineCount-1, iLineInfo), KErrNone, _L("GT83-TVOICE-0AAA"));
-		INFO_PRINTF4(_L("Line %d (%S) cap flags = 0x%x"),
-			lineCount-1, &iLineInfo.iName,iLineInfo.iLineCapsFlags);
-		if (iLineInfo.iLineCapsFlags&RLine::KCapsVoice)
-			{
-			INFO_PRINTF3(_L("Line %d (%S) has voice capability"), lineCount-1, &iLineInfo.iName);
-			iLineIndex=lineCount-1;
-			break;
-			}
-		}
-	TESTL(lineCount>0);
-
-	// Status of the Phone
-	INFO_PRINTF1(_L("Get the Phone's Status..."));
-	RPhone::TStatus phoneStatus;
-	ret=iPhone.GetStatus(phoneStatus);
-	if (ret==KErrNotSupported)
-		{
-		INFO_PRINTF1(_L("Get Phone Status is NOT Supported"));
-		}
-	if (ret==KErrNone)
-		{
-		INFO_PRINTF1(_L("Get Phone Status is successful."));
-		CHECKPOINT(phoneStatus.iMode, RPhone::EModeIdle, _L("GT83-TVOICE-0AAA"));
-		INFO_PRINTF1(_L("The phone is currently Idle"));
-		}
-
-	// Notification Cancel Requests : Modem Detected
-	INFO_PRINTF1(_L("Notify Modem Detected Cancel Request..."));
-	RPhone::TModemDetection detected;
-	iPhone.NotifyModemDetected(iStatus, detected);
-	iPhone.NotifyModemDetectedCancel();
-	User::WaitForRequest(iStatus);
-	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Notify Modem Detected Cancel status: %d")), iStatus.Int());
-
-	// Notification Cancel Requests : Caps Change
-	INFO_PRINTF1(_L("Notify Caps Change Cancel Request..."));
-	iPhone.NotifyCapsChange(iStatus, phoneCaps);
-	iPhone.NotifyCapsChangeCancel();
-	User::WaitForRequest(iStatus);
-	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Notify Caps Change Cancel status: %d")), iStatus.Int());
-	return TestStepResult();
-	}
-//------------------------------------------------------------------
-
-CTestDtmf::CTestDtmf()
-/** Each test step i7nitialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestDtmf"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestDtmf::doTestStepL()
-/** DTMF tests suite
- * @test GT83-TVOICE-038.01 Test retieval of DTMF capabilities where the TSY/ME supports sending a string of DTMF tones, containing one or more tone(s).
- * @test GT83-TVOICE-040.02 Test sending a valid string of DTMF tone characters (p,0,1,2,3,4,5,6,7,8,9,0,w,A,B,C,D,*,#)
- * @test GT83-TVOICE-041.00 Test sending a single DTMF tone (Generic)
- * @test GT83-TVOICE-042.01 Test setting a request for a notification of a stop in a DTMF string
- * @test GT83-TVOICE-042.03 Test the ability to continue sending tones when a stop is encountered in the middle of a DTMF string
-*/
-	{
-	_LIT(KDtmfString0,"45p6789ABCDp");
-	_LIT(KDtmfString1,"01w23");
-
-	//to make sure that line and call will be closed in leave case
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	TESTL(iLine.Open(iPhone,KVoiceLineName)==KErrNone);
-	INFO_PRINTF1(_L("Opened Line object"));
-
-	TName callName;
-	TESTL(iVoiceCall.OpenNewCall(iLine,callName)==KErrNone);
-	INFO_PRINTF1(_L("Opened Call object"));
-
-	TRequestStatus reqStatus0, reqStatus1;
-
-	INFO_PRINTF2(_L("Dialling %S "),&KGoodNumber);
-	iVoiceCall.Dial(reqStatus0,KGoodNumber);
-	User::WaitForRequest(reqStatus0);
-	// Wait for the Call Status Change notification
-	TESTL(reqStatus0==KErrNone);
-	INFO_PRINTF1(_L("...Call is Connected"));
-
-	INFO_PRINTF1(_L("Testing an erroneous DTMF String Tx Continue"));
-	TESTL(iPhone.ContinueDTMFStringSending(ETrue)==KErrNotReady);
-
-	INFO_PRINTF1(_L("Test DTMF Caps"));
-	TUint32 dtmfCaps;
-	CHECKPOINT(iPhone.GetDTMFCaps(dtmfCaps), KErrNone, _L("GT83-TVOICE-038.01"));
-	TESTL(((dtmfCaps &(RMobilePhone::KCapsSendDTMFString
-				   | RMobilePhone::KCapsSendDTMFSingleTone)) !=0) );
-
-	INFO_PRINTF1(_L("Test Send DTMF String"));
-	iPhone.SendDTMFTones(reqStatus0,KDtmfString0) ;
-	User::After(1000000);
-
-	TChar character('1');
-	CHECKPOINT(iPhone.StartDTMFTone(character), KErrInUse, _L("GT83-TVOICE-041.00"));
-	User::After(1000000);
-	CHECKPOINT(iPhone.StopDTMFTone(), KErrInUse, _L("GT83-TVOICE-040.09"));
-	User::WaitForRequest(reqStatus0);
-	TESTL(reqStatus0==KErrNone);
-
-	INFO_PRINTF1(_L("Test Start & Stop DTMF Tone"));
-	CHECKPOINT(iPhone.StartDTMFTone(character), KErrNone, _L("GT83-TVOICE-041.00"));
-	User::After(1000000);
-	CHECKPOINT(iPhone.StopDTMFTone(), KErrNone, _L("GT83-TVOICE-040.09"));
-
-	INFO_PRINTF1(_L("Test Send DTMF String with wait & continue"));
-	iPhone.NotifyStopInDTMFString(reqStatus1);
-
-	iPhone.SendDTMFTones(reqStatus0,KDtmfString1);
-	CHECKPOINT(reqStatus0.Int(), KRequestPending, _L("GT83-TVOICE-040.02"));
-	User::WaitForRequest(reqStatus1);
-	TESTL(reqStatus1==KErrNone);
-	CHECKPOINT(iPhone.ContinueDTMFStringSending(ETrue), KErrNone, _L("GT83-TVOICE-042.03"));
-	User::WaitForRequest(reqStatus0);
-	TESTL(reqStatus0==KErrNone);
-
-	INFO_PRINTF1(_L("Test Send DTMF String with wait & terminate"));
-	iPhone.NotifyStopInDTMFString(reqStatus1);
-	CHECKPOINT(reqStatus1.Int(), KRequestPending,_L("GT83-TVOICE-042.01"));
-	iPhone.SendDTMFTones(reqStatus0,KDtmfString1);
-	CHECKPOINT(reqStatus0.Int(), KRequestPending,_L("GT83-TVOICE-040.02"));
-	User::WaitForRequest(reqStatus1);
-	TESTL(reqStatus1==KErrNone);
-	CHECKPOINT(iPhone.ContinueDTMFStringSending(EFalse), KErrNone, _L("GT83-TVOICE-042.03"));
-	User::WaitForRequest(reqStatus0);
-	TESTL(reqStatus0==KErrAccessDenied);
-
-	INFO_PRINTF1(_L("Test Send DTMF String terminated early by a call closure"));
-	iPhone.SendDTMFTones(reqStatus0,KDtmfString0);
-	CHECKPOINT(reqStatus0.Int(), KRequestPending,_L("GT83-TVOICE-040.02"));
-	User::After(1000000);
-	INFO_PRINTF1(_L("Hanging up..."));
-	TESTL(iVoiceCall.HangUp()==KErrNone);
-	User::WaitForRequest(reqStatus0);
-	TESTL(reqStatus0==KErrEtelNoCarrier);
-
-	INFO_PRINTF1(_L("Test Sending DTMF Strings while there is no active call."));
-	CHECKPOINT(iPhone.ContinueDTMFStringSending(ETrue), KErrNotReady, _L("GT83-TVOICE-042.03"));
-	iPhone.SendDTMFTones(reqStatus0,KDtmfString0);
-	User::WaitForRequest(reqStatus0);
-	TESTL(reqStatus0==KErrEtelCallNotActive);
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-	}
-
-//------------------------------------------------------------------
-
-CTestRemoteHangup::CTestRemoteHangup()
-/** Each test step initialises it's own name
-*/
-	{
-	// store the name of this test case
-	// this is the name that is used by the script file
-	SetTestStepName(_L("TestRemoteHangup"));
-	}
-//------------------------------------------------------------------
-
-TVerdict CTestRemoteHangup::doTestStepL()
-/**	 Tests line status function
- * @test GT83-TVOICE-XXX.XX "Test remote hangup of connected call"
-*/
-	{
-	INFO_PRINTF1(_L("Test Remote Hangup"));
-
-	RCall::TStatus lineStatus;
-	TName callName;
-	TBuf<16> goodNumber ;
-	GetGoodNumber(goodNumber) ;
-
-	// Open a Voice Line and Call
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-XXX.XX"));
-
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-XXX.XX"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
-
-	INFO_PRINTF2(_L("Dialling %S...."), &goodNumber);
-	iVoiceCall.Dial(iStatus, goodNumber);
-	User::WaitForRequest(iStatus);
-	TESTL(iStatus==KErrNone);
-
-	// Trigger remote hangup
-	RCall::TStatus notifyLineStatus;
-	TRequestStatus notifyStatus;
-	iLine.NotifyStatusChange(notifyStatus, notifyLineStatus);
-	TESTL(HangMeUpDear() == KErrNone);
-	User::WaitForRequest(notifyStatus);
-	TESTL(notifyStatus.Int() == KErrNone);
-	CHECKPOINT(notifyLineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-XXX.XX")) ;
-	TInt ret = iLine.GetStatus(lineStatus);
-	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-XXX.XX")) ;
-	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-XXX.XX")) ;
-
-	// Close the line and call
-	iVoiceCall.Close();
-	iLine.Close();
-
-	return TestStepResult();
-	}
-
-
-CTestCallDuration::CTestCallDuration()
-	{
-
-	SetTestStepName(_L("TestCallDuration"));
-	}
-
-CTestCallDuration::~CTestCallDuration()
-	{
-
-	}
-
-TVerdict CTestCallDuration::doTestStepL()
-	{
-	TVerdict   Ret,Ret1;
-	INFO_PRINTF1(_L("Call Duration Test"));
-	
-	Ret = RunTestL(FALSE);
-	Ret1 = RunTestL(TRUE);	
-	if(Ret1 == EPass && Ret == EPass)	
-		Ret = EPass;
-	else
-		Ret = EFail;
-	return Ret;
-	}
-
-TVerdict CTestCallDuration::RunTestL(TBool aBRingOut)
-	{
-	//RPhone::TLineInfo lineInfo;
-	TRequestStatus   statDuration;
-	TTimeIntervalSeconds CallLengthDuration,CallLength;
-	TName CallName ;
-
-	CleanupClosePushL(iLine);
-	CleanupClosePushL(iVoiceCall);
-
-	INFO_PRINTF1(_L("Opening Voice Line"));
-	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("Call Duration Test 1"));
-	INFO_PRINTF1(_L("Opening New Voice Call"));
-	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("Call Duration Test 2"));
-	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
-
-//Test Call Duration 
-	// start notification of call duration.
-	INFO_PRINTF1(_L("Testing Call Duration"));
-	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
-	RingOrDialL(aBRingOut);
-
-	User::WaitForRequest(statDuration);
-	CHECKPOINT(CallLengthDuration.Int() == 1,TRUE,_L(""));
-	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLengthDuration.Int());
-	User::After(5200000);
-	iVoiceCall.GetCallDuration(CallLength);
-	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLength.Int());
-	CHECKPOINT(CallLength.Int() >= 5 ,TRUE,_L("Call Duration Test 3"));
-	
-	// Hang up the Call
-	INFO_PRINTF1(_L("Hanging up the call"));
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	INFO_PRINTF1(_L("HangUp successful"));
-	
-	iVoiceCall.GetCallDuration(CallLength);
-	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLength.Int());
-	
-	TInt numberOfNotifs=0 ;
-	for (; statDuration==KErrNone ;numberOfNotifs++)
-	{
-	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
-	WaitWithTimeout(statDuration,5*KOneSecond);
-	}
-	
-	User::After(6000000);
-//Test Call Duration notification
-
-	INFO_PRINTF1(_L("Testing Call Duration Notification"));
-	RingOrDialL(aBRingOut);
-	User::After(2500000);
-	iVoiceCall.GetCallDuration(CallLength);
-	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLength.Int());
-	CHECKPOINT(CallLength.Int() == 2,TRUE,_L("Call Duration Test 4"));
-
-	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
-	User::WaitForRequest(statDuration);
-	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLengthDuration.Int());
-
-	CHECKPOINT(CallLengthDuration.Int() >= 2,TRUE,_L("Call Duration Test 5"));
-	
-	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
-	iVoiceCall.NotifyCallDurationChangeCancel();
-	WaitWithTimeout(statDuration,10*KOneSecond);
-	CHECKPOINT((statDuration.Int()==KErrNone)||(statDuration.Int()==KErrCancel), TRUE, _L("Call Duration Test 6"));
-
-	INFO_PRINTF1(_L("Hanging up the call"));
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	INFO_PRINTF1(_L("HangUp successful"));
-
-//
-	User::After(6000000);
-	
-//Test NotifyCallDurationChangeCancel
-	INFO_PRINTF1(_L("Testing Call Duration Notification Cancel"));
-	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
-	RingOrDialL(aBRingOut);
-	iVoiceCall.NotifyCallDurationChangeCancel();
-	WaitWithTimeout(statDuration,10*KOneSecond);
-	CHECKPOINT(iStatus.Int(), KErrNone, _L("Call Duration Test 7"));
-	
-	User::WaitForRequest(statDuration);
-	// Hang up the Call
-	INFO_PRINTF1(_L("Hanging up the call"));
-	iVoiceCall.HangUp(iStatus);
-	User::WaitForRequest(iStatus);
-	INFO_PRINTF1(_L("HangUp successful"));
-//
-
-	// Close the line and call
-	CleanupStack::PopAndDestroy(&iVoiceCall);
-	CleanupStack::PopAndDestroy(&iLine);
-
-	return TestStepResult();
-
-	}
-
-TBool CTestCallDuration::RingOrDialL(TBool aBRingOut)
-	{
-	if(!aBRingOut)
-		{
-		INFO_PRINTF1(_L("Please ring the phone"));
-		TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
-		iVoiceCall.AnswerIncomingCall(iStatus);		// wait for a call
-		WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 60 seconds
-		CHECKPOINT(iStatus.Int(), KErrNone, _L("Call Duration Test 8"));
-		}
-	else
-		{
-		INFO_PRINTF2(_L("Dialling %S"),&KGoodNumber);
-		iVoiceCall.Dial(iStatus,KGoodNumber);
-		User::WaitForRequest(iStatus);
-		// Wait for the Call Status Change notification
-		TESTL(iStatus==KErrNone);
-		INFO_PRINTF1(_L("...Call is Connected"));
-		}
-	return TRUE;
-	}
+// Copyright (c) 2003-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
+*/
+
+#include "Te_SimVoice.h"
+
+const TInt KTenPartOfSec = 100000 ;
+const TInt KOneSecond=1000000;	// Used in a time out function, 1 second (in microSeconds)
+const TInt KTenSeconds=10000000;	// Used in a time out function, 10 seconds (in microSeconds)
+ 
+//------------------------------------------------------------------
+
+CTestLineStatusIncommingCall::CTestLineStatusIncommingCall()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestLineStatusIncommingCall"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestLineStatusIncommingCall::doTestStepL()
+/**	 Tests line status function
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-004.00 Test retrieval of a voice line's current status (Generic)
+ * @test GT83-TVOICE-004.02 "Test retrieval of a voice line's current status when the line's status is ""Idle"""
+ * @test GT83-TVOICE-004.04 "Test retrieval of a voice line's current status when the line's status is ""Ringing"""
+ * @test GT83-TVOICE-004.07 "Test retrieval of a voice line's current status when the line's status is ""Connected"""
+ * @test GT83-TVOICE-004.08 "Test retrieval of a voice line's current status when the line's status is ""Hanging up"""
+ * @test GT83-TVOICE-008.02 Test for a notification when there is an incoming call on a voice line
+ * @test GT83-TVOICE-015.05 Test opening an existing call from a voice line by specifying the name of the line and the name of an existing call
+ * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
+ * @test GT83-TVOICE-030.00 Test retrieval of a mobile voice line's current status (Generic)
+ * @test GT83-TVOICE-030.02 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""Dialling"""
+ * @test GT83-TVOICE-030.03 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""Ringing"""
+ * @test GT83-TVOICE-030.06 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""Disconnecting"""
+ * @test GT83-TVOICE-030.07 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""on hold"""
+ * @test GT83-TVOICE-031.01 Test setting a request for a notification of a change in the status of the mobile voice line
+*/
+{
+	INFO_PRINTF1(_L("Test Line Status"));
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	TName callName;
+
+	RCall::TStatus lineStatus;
+	TBuf<16> GoodNumber ;
+	GetGoodNumber(GoodNumber) ;
+	// Open a Voice Line and Call
+	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
+
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	/* @test GT83-AT-36	Test retrieval of the current call status when it is idle*/
+	TInt ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
+
+	RMobileCall::TMobileCallStatus mobileLineStatus;
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-031.01")) ;
+
+	INFO_PRINTF1(_L("Please ring the phone"));
+
+	/* @test GT83-AT-024	Test setting notification of an incoming call on a Voice Line */
+	iLine.NotifyIncomingCall(iStatus, callName);	// wait for a call
+	TESTL(CallMeDear() == KErrNone) ;		// AMC - Added
+	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.02")) ;
+	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
+
+	/* @test GT83-AT-36	Test retrieval of the current call status when it is ringing*/
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusRinging, _L("GT83-TVOICE-004.04")) ;
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusRinging, _L("GT83-TVOICE-030.003")) ;
+
+	INFO_PRINTF1(_L("Phone is ringing..."));
+	//Test for incomming Voice Call
+	TestLineCapabilitiesL();
+
+	/* @test GT83-AT-028	Test opening a new call by specifying the name of a line
+	*/
+	ret = iVoiceCall.OpenExistingCall(iLine, callName);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
+
+	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
+	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
+	iVoiceCall.AnswerIncomingCall(iStatus);
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 2 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.04")) ;
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-030.03")) ;
+	TestLineCapabilitiesL();
+
+	/* @test GT83-AT-36	Test retrieval of the current call status when it is connected*/
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.07")) ;
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-030.07")) ;
+
+
+	INFO_PRINTF1(_L("Please stay connected... the test will hang up shortly"));
+	User::After(10*KOneSecond);
+
+	INFO_PRINTF1(_L("Hanging Up"));
+	iVoiceCall.HangUp(iStatus);
+
+	/* @test GT83-AT-36	Test retrieval of the current call status when it is hang up*/
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-004.08")) ;
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-034.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusDisconnecting, _L("GT83-TVOICE-034.09")) ;
+
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;  //???  line 825
+
+	/* @test GT83-AT-36	Test retrieval of the current call status when it is idle*/
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-030.02")) ;
+
+	/* @test GT83-AT-36	Test retrieval of the current call status when it is idle*/
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.02")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+CTestLineNotificationsIncommingCall::CTestLineNotificationsIncommingCall()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestLineNotificationsIncommingCall"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestLineNotificationsIncommingCall::doTestStepL()
+/** Tests line notifications
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-008.02 Test for a notification when there is an incoming call on a voice line
+ * @test GT83-TVOICE-009.01 Test setting notification of a change in hook status of a voice line
+ * @test GT83-TVOICE-009.02 "Test notification of a change in hook status of a voice line from ""off"" to ""on"""
+ * @test GT83-TVOICE-009.03 "Test notification of a change in hook status of a voice line from ""on"" to off"""
+ * @test GT83-TVOICE-010.01 "Test notification of a change in the status of the voice line from ""idle"" to ""ringing"" to ""answering"" to ""connected"" to ""hanging up"" to ""idle""
+ * @test GT83-TVOICE-011.02 Test notification of a call being added to a voice line that currently has no calls
+ * @test GT83-TVOICE-015.05 Test opening an existing call from a voice line by specifying the name of the line and the name of an existing call
+ * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
+ * @test GT83-TVOICE-031.01 Test setting a request for a notification of a change in the status of the mobile voice line
+ * @test GT83-TVOICE-031.07 "Test for a notification of a change in status of the mobile voice line from ""connected"" to ""disconnecting"""
+ * @test GT83-TVOICE-031.08 "Test for a notification of a change in status of the mobile voice line from ""disconnecting"" to ""idle"""
+ * @test GT83-TVOICE-031.09 "Test for a notification of a change in status of the mobile voice line from ""idle"" to ""ringing"""
+ * @test GT83-TVOICE-031.10 "Test for a notification of a change in status of the mobile voice line from ""ringing"" to ""answering"""
+ * @test GT83-TVOICE-031.11 "Test for a notification of a change in status of the mobile voice line from ""answering"" to ""connected"""
+*/
+{
+	INFO_PRINTF1(_L("Test Line Notifications"));
+	TBuf<16> GoodNumber ;
+	GetGoodNumber(GoodNumber) ;
+
+	// NotifyIncomingCall and NotifyStatusChange
+	TName callName1;
+	TName callName2;
+	TInt ret = KErrNone;
+	RCall::TStatus lineStatus;
+	RMobileCall::TMobileCallStatus mobileLineStatus;
+	RCall::THookStatus hookStatus;
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	INFO_PRINTF1(_L("Please ring the phone"));
+
+	iLine.NotifyIncomingCall(iStatus, callName1);	// wait for a call
+
+	//GT83-AT-026	Test setting notification of a change in the status of the Voice Line
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+
+	//GT83-AT-037	Test setting notification of a change in hook status of a Voice Line	void RLine::NotifyHookChange(TRequestStatus& aStatus, THookStatus& aHookStatus)	Function does not produce any unexpected errors. aStatus = KErrPending
+	iLine.NotifyHookChange(iStatus4, hookStatus);
+
+    /* GT83-AT-025	Test notification of a call being added to a Voice Line 	*/
+	iLine.NotifyCallAdded(iStatus5, callName2);
+
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-008.02")) ;
+	CHECKPOINT(iStatus2.Int(), KRequestPending, _L("GT83-TVOICE-010.01")) ;
+	CHECKPOINT(iStatus3.Int(), KRequestPending, _L("GT83-TVOICE-031.01")) ;
+	CHECKPOINT(iStatus4.Int(), KRequestPending, _L("GT83-TVOICE-009.01")) ;
+	CHECKPOINT(iStatus5.Int(), KRequestPending, _L("GT83-TVOICE-0011.01")) ;
+
+	TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
+
+	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.02")) ;
+
+    // @test GT83-AT-026	Test notification of a change in the status of the Voice Line
+	// from "idle" to "ringing"
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.02")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusRinging, _L("GT83-TVOICE-010.02")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.09")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusRinging, _L("GT83-TVOICE-031.09")) ;
+
+	/* GT83-AT-025	Test notification of a call being added to a Voice Line
+	that currently has no calls*/
+	User::WaitForRequest(iStatus5);
+	CHECKPOINT(iStatus5.Int(), KErrNone, _L("GT83-TVOICE-011.02")) ;
+	CHECKPOINT(callName2 == callName1, 1,  _L("GT83-TVOICE-011.02")) ;
+
+	INFO_PRINTF1(_L("Phone is ringing... Now answering..."));
+
+	/* @test GT83-AT-026	Test notification of a change in the status of the Voice Line from
+	 "idle" to "ringing" to "answering" to "connected" to "hanging up" to "idle"
+	 */
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+
+	ret = iVoiceCall.OpenExistingCall(iLine, callName1);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
+
+	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
+	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
+	iVoiceCall.AnswerIncomingCall(iStatus);
+
+    // GT83-AT-026	Test notification of a change in the status of the Voice Line
+	// from "ringing" to "answering"
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.01")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusAnswering, _L("GT83-TVOICE-010.01")) ;
+
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 2 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;	  //wrong code -1632960000
+
+
+    // @test GT83-AT-026	Test notification of a change in the status of the Voice Line
+	// from "answering"	to "connecting"
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.01")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-010.01")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.10")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusAnswering, _L("GT83-TVOICE-031.10")) ;
+
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.11")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.11")) ;
+
+	User::WaitForRequest(iStatus4);
+	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-009.02")) ;
+	CHECKPOINT(hookStatus, RCall::EHookStatusOff, _L("GT83-TVOICE-009.02")) ;
+
+	// now hangup call
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+	iLine.NotifyHookChange(iStatus4, hookStatus);
+
+	INFO_PRINTF1(_L("Call connected - now hanging up..."));
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;
+
+    //GT83-AT-026	Test notification of a change in the status of the Voice Line
+	// from "connecting" to "hanging up"
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.02")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-010.02")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.07")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusDisconnecting, _L("GT83-TVOICE-031.07")) ;
+
+	// @test GT83-AT-026	Test notification of a change in the status of the data
+	// line from "hanging up" to "idle"
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.02")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-010.02")) ;
+
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.08")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-031.08")) ;
+
+	//!< @test GT83-AT-037	Test notification of a change in hook status of a Voice Line
+	//!<  from "off" to "on" aHookStatus = EHookStatusOff before the hook status changes,
+	//!< and EHookStatusOn after the hook status changes
+	User::WaitForRequest(iStatus4);
+	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-009.03")) ;
+	CHECKPOINT(hookStatus, RCall::EHookStatusOn, _L("GT83-TVOICE-009.03")) ;
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestCallNotificationsIncommingCall::CTestCallNotificationsIncommingCall()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestCallNotificationsIncommingCall"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestCallNotificationsIncommingCall::doTestStepL()
+/**
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-002.00 Test retrieval of a voice line's capabilities (Generic)
+ * @test GT83-TVOICE-008.01 Test setting notification of an incoming call on a voice line
+ * @test GT83-TVOICE-015.05 Test opening an existing call from a voice line by specifying the name of the line and the name of an existing call
+ * @test GT83-TVOICE-016.04 "Test retrieval of the current call status when the call's status is ""ringing"""
+ * @test GT83-TVOICE-016.05 "Test retrieval of the current call status when the call's status is ""answering"""
+ * @test GT83-TVOICE-018.01 Test setting notification of a change in the call's capabilities
+ * @test GT83-TVOICE-018.02 Test notification of a change in the call's capabilities as the call's state changes (eg. From idle to connected). Print the call's capabilities to screen
+ * @test GT83-TVOICE-020.01 Test setting notification of a change in hook status of a voice call
+ * @test GT83-TVOICE-020.02 "Test notification of a change in hook status of a voice call from ""off"" to ""on"""
+ * @test GT83-TVOICE-020.03 "Test notification of a change in hook status of a voice call from ""on"" to off"""
+ * @test GT83-TVOICE-021.01 Test setting notification of a change in the status of the voice call
+ * @test GT83-TVOICE-021.02 "Test notification of a change in the status of the voice call from ""idle"" to ""ringing"" to ""answering"" to ""connected"" to ""hanging up"" to ""idle""
+ * @test GT83-TVOICE-022.01 Test setting notification of a change in the voice call's duration
+ * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
+ * @test GT83-TVOICE-033.01 Test setting notification of a change in the call's dynamic call control and call event capabilities
+ * @test GT83-TVOICE-033.02 Test notification of a change in the call's dynamic call control and call event capabilities. Print the call's capabilities to screen
+ * @test GT83-TVOICE-034.04 "Test retrieval of the current status of the voice call when the call's status is ""ringing"""
+ * @test GT83-TVOICE-035.01 Test setting a request for a notification of a change in the status of the mobile voice call
+ * @test GT83-TVOICE-035.07 "Test for a notification of a change in status of the mobile voice call from ""connected"" to ""disconnecting"""
+ * @test GT83-TVOICE-035.08 "Test for a notification of a change in status of the mobile voice call from ""disconnecting"" to ""idle"""
+ * @test GT83-TVOICE-035.10 "Test for a notification of a change in status of the mobile voice call from ""ringing"" to ""answering"""
+ * @test GT83-TVOICE-035.11 "Test for a notification of a change in status of the mobile voice call from ""answering"" to ""connected"""
+*/
+	{
+	// Post call status change notifications
+	TName callName1;
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	RCall::TStatus callStatus;
+	RMobileCall::TMobileCallStatus mobileCallStatus;
+
+	RCall::TCaps caps;
+	RCall::THookStatus hookStatus;
+	TTimeIntervalSeconds time;
+
+	RMobileCall::TMobileCallCapsV1 mobileCallCaps;
+	RMobileCall::TMobileCallCapsV1Pckg mobileCallCapsPckg(mobileCallCaps);
+
+	INFO_PRINTF1(_L("Test Call Notifications"));
+	// Open a Voice Line and Call
+	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	INFO_PRINTF1(_L("Please ring the phone"));
+
+	iLine.NotifyIncomingCall(iStatus, callName1);	// wait for a call
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-008.01")) ;
+
+
+    TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
+
+
+	WaitWithTimeout(iStatus,60*KOneSecond);				// but timeout after 60 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.01")) ;
+
+	TInt ret = iVoiceCall.OpenExistingCall(iLine, callName1);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
+
+	iVoiceCall.GetStatus(callStatus);
+	CHECKPOINT(callStatus, RCall::EStatusRinging, _L("GT83-TVOICE-016.04")) ;
+
+	iVoiceCall.GetMobileCallStatus(mobileCallStatus);
+	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusRinging, _L("GT83-TVOICE-034.04")) ;
+
+	ret=iVoiceCall.GetCaps(caps);
+	Print_TCapsEnum(caps) ;
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-002.00")) ;
+	TESTL((caps.iFlags & (RCall::KCapsVoice | RCall::KCapsAnswer)));
+
+//	INFO_PRINTF1(_L("Opening New Voice Call"));
+//	CHECKPOINT(iiVoiceCall.OpenExistingCall(iLine, callName2), KErrNone, _L("GT83-TVOICE-013.06")) ;
+
+	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
+	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
+#ifndef SIM_TSY
+	iVoiceCall.NotifyCapsChange(iStatus4, caps);
+#endif
+	iVoiceCall.NotifyHookChange(iStatus5, hookStatus);
+	iVoiceCall.NotifyCallDurationChange(iStatus6, time) ;
+	iVoiceCall.NotifyMobileCallCapsChange(iStatus7, mobileCallCapsPckg);
+
+	INFO_PRINTF1(_L("Phone is ringing... Now answering..."));
+	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
+	iVoiceCall.AnswerIncomingCall(iStatus);
+
+	//doesn't work for MM.TSY iVoiceCall.GetStatus(callStatus);
+	//CHECKPOINT(callStatus, RCall::EStatusAnswering, _L("GT83-TVOICE-016.05")) ;
+
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 2 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
+
+
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
+	CHECKPOINT(callStatus, RCall::EStatusAnswering, _L("GT83-TVOICE-021.02")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.01")) ;
+	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusAnswering, _L("GT83-TVOICE-035.10")) ;
+
+	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.01")) ;
+	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-035.11")) ;
+
+#ifndef SIM_TSY
+	User::WaitForRequest(iStatus4);
+	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-018.01")) ;
+	Print_TCapsEnum(caps) ;
+	CHECKPOINT(caps.iFlags, RCall::KCapsVoice, _L("GT83-TVOICE-018.02")) ;
+
+	iVoiceCall.NotifyCapsChange(iStatus4, caps);
+	User::WaitForRequest(iStatus4);
+	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-018.01")) ;
+	CHECKPOINT(caps.iFlags, (RCall::KCapsVoice | RCall::KCapsHangUp), _L("GT83-TVOICE-018.01")) ;
+#endif
+
+	User::WaitForRequest(iStatus5);
+	CHECKPOINT(iStatus5.Int(), KErrNone, _L("GT83-TVOICE-020.01")) ;
+	CHECKPOINT(hookStatus, RCall::EHookStatusOff, _L("GT83-TVOICE-020.03")) ;
+
+	User::WaitForRequest(iStatus6);
+
+#ifndef SIM_TSY
+	CHECKPOINT(iStatus6.Int(), KErrNone, _L("GT83-TVOICE-022.01")) ;
+#endif
+
+	if (iStatus6==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Notify Call Duration Change is NOT Supported"));
+		}
+	if (iStatus6==KErrNone)
+		{
+		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), time.Int());
+		}
+
+	User::WaitForRequest(iStatus7);
+#ifndef SIM_TSY
+	CHECKPOINT(iStatus7.Int(), KErrNone, _L("GT83-TVOICE-033.01")) ;
+	CHECKPOINT(mobileCallCaps.iCallControlCaps, RCall::KCapsVoice, _L("GT83-TVOICE-033.02")) ;
+#endif
+
+#ifndef SIM_TSY //MAY hang the app.
+	iVoiceCall.NotifyMobileCallCapsChange(iStatus7, mobileCallCapsPckg);
+	User::WaitForRequest(iStatus7);
+	CHECKPOINT(iStatus7.Int(), KErrNone, _L("GT83-TVOICE-033.01")) ;
+	CHECKPOINT(mobileCallCaps.iCallControlCaps, (RCall::KCapsVoice | RCall::KCapsHangUp), _L("GT83-TVOICE-033.02")) ;
+#endif
+
+	// now hangup call
+	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
+	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
+
+	INFO_PRINTF1(_L("Call connected - now hanging up..."));
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-020.01")) ;	//sometimes timed out -33
+
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
+	CHECKPOINT(callStatus, RCall::EStatusConnected, _L("GT83-TVOICE-021.02")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.07")) ;
+	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusDisconnecting, _L("GT83-TVOICE-035.07")) ;
+
+	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
+	CHECKPOINT(callStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-021.02")) ;
+
+	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.01")) ;
+	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-035.08")) ;
+
+	TESTL(iStatus == KErrNone) ;
+	TESTL(iStatus2 == KErrNone) ;
+	TESTL(iStatus3 == KErrNone) ;
+	TESTL(iStatus4 == KErrNone) ;
+	TESTL(iStatus5 == KErrNone) ;
+#ifndef SIM_TSY
+	TESTL(iStatus6 == KErrNone) ;
+	TESTL(iStatus7 == KErrNone) ;
+#endif
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestCallNotificationsOutgoingCall::CTestCallNotificationsOutgoingCall()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestCallNotificationsOutgoingCall"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestCallNotificationsOutgoingCall::doTestStepL()
+/**
+ @test GT83-TVOICE-016.08	Test retrieval of the current call status when the call's status is "hanging up"
+*/
+	{
+	// Post call status change notifications
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+    TName CallName ;
+
+	RCall::TStatus callStatus;
+	RMobileCall::TMobileCallStatus mobileCallStatus;
+
+	//TTimeIntervalSeconds time;
+ 	//RMobileCall::TMobileCallCapsV1 mobileCallCaps;
+	//RMobileCall::TMobileCallCapsV1Pckg mobileCallCapsPckg(mobileCallCaps);
+
+	TBuf<16> GoodNumber ;
+	GetGoodNumber(GoodNumber) ;
+
+	INFO_PRINTF1(_L("Test Call Notifications"));
+	// Open a Voice Line and Call
+	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
+
+	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
+	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
+
+	// Now test call status during an outgoing call
+	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
+	iVoiceCall.Dial(iStatus, GoodNumber);
+
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
+	CHECKPOINT(callStatus, RCall::EStatusDialling, _L("GT83-TVOICE-021.03")) ;
+	iVoiceCall.GetStatus(callStatus) ;
+	CHECKPOINT(callStatus, RCall::EStatusDialling, _L("GT83-TVOICE-016.03")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-035.01")) ;
+	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusDialling, _L("GT83-TVOICE-035.02")) ;
+	iVoiceCall.GetMobileCallStatus(mobileCallStatus) ;
+	CHECKPOINT(mobileCallStatus, RMobileCall::EStatusDialling, _L("GT83-TVOICE-034.03")) ;
+
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 60 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
+
+	// now hangup call
+	iVoiceCall.NotifyStatusChange(iStatus2, callStatus);
+	iVoiceCall.NotifyMobileCallStatusChange(iStatus3, mobileCallStatus);
+
+	INFO_PRINTF1(_L("Call connected - now hanging up..."));
+	iVoiceCall.HangUp(iStatus);
+
+	//doesn't work for MM.TSY
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-021.01")) ;
+	//CHECKPOINT(callStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-021.03")) ;
+
+	User::WaitForRequest(iStatus3);
+	iVoiceCall.GetMobileCallStatus(mobileCallStatus) ;
+	TEST_CHECKL(mobileCallStatus, RMobileCall::EStatusHangingUp, _L("GT83-TVOICE-016.08")) ;
+
+
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-020.01")) ;	//sometimes timed out -33
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestLineNotificationsOutgoingCall::CTestLineNotificationsOutgoingCall()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestLineNotificationsOutgoingCall"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestLineNotificationsOutgoingCall::doTestStepL()
+/** Tests line notifications
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-009.02 "Test notification of a change in hook status of a voice line from ""off"" to ""on"""
+ * @test GT83-TVOICE-009.03 "Test notification of a change in hook status of a voice line from ""on"" to off"""
+ * @test GT83-TVOICE-010.03 "Test notification of a change in the status of the voice line from ""idle"" to ""dialling"" to ""connecting"" to ""connected"" to ""hanging up"" to ""idle""
+ * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
+ * @test GT83-TVOICE-031.02 "Test for a notification of a change in status of the mobile voice line from ""idle"" to ""dialling"""
+ * @test GT83-TVOICE-031.04 "Test for a notification of a change in status of the mobile voice line from ""connecting"" to ""connected"""
+ * @test GT83-TVOICE-031.07 "Test for a notification of a change in status of the mobile voice line from ""connected"" to ""disconnecting"""
+ * @test GT83-TVOICE-031.08 "Test for a notification of a change in status of the mobile voice line from ""disconnecting"" to ""idle"""
+*/
+	{
+	INFO_PRINTF1(_L("Test Line Notifications"));
+	TBuf<16> GoodNumber ;
+	GetGoodNumber(GoodNumber) ;
+
+	// NotifyIncomingCall and NotifyStatusChange
+	TName callName1;
+	//TName callName2;
+	//TInt ret = KErrNone;
+	RCall::TStatus lineStatus;
+	RMobileCall::TMobileCallStatus mobileLineStatus;
+	RCall::THookStatus hookStatus;
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, callName1), KErrNone, _L("GT83-TVOICE-014.05"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &callName1);
+
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+	iLine.NotifyHookChange(iStatus4, hookStatus);
+
+	// Now test call status during an outgoing call
+	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
+	iVoiceCall.Dial(iStatus, GoodNumber);
+
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusDialling, _L("GT83-TVOICE-010.03")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.02")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusDialling, _L("GT83-TVOICE-031.02")) ;
+
+	User::WaitForRequest(iStatus4);
+	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-009.03")) ;
+	CHECKPOINT(hookStatus, RCall::EHookStatusOff, _L("GT83-TVOICE-009.03")) ;
+
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+	iLine.NotifyHookChange(iStatus4, hookStatus);
+
+#ifdef SIM_TSY //It has connecting status
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusConnecting, _L("GT83-TVOICE-010.03")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.03")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnecting, _L("GT83-TVOICE-031.03")) ;
+
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+#endif
+
+	User::WaitForRequest(iStatus); //end of dial
+
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-010.03")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.04")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.04")) ;
+
+	INFO_PRINTF1(_L("Call connected - hanging up..."));
+
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+
+	User::After(10*KOneSecond);
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;
+
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-010.03")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.07")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusDisconnecting, _L("GT83-TVOICE-031.07")) ;
+
+	/* @test GT83-AT-037	Test notification of a change in hook status of a data
+	 line from "on" to off"	aHookStatus = EHookStatusOn before the hook status changes,
+	 */
+	User::WaitForRequest(iStatus4);
+	CHECKPOINT(iStatus4.Int(), KErrNone, _L("GT83-TVOICE-009.02")) ;
+	CHECKPOINT(hookStatus, RCall::EHookStatusOn, _L("GT83-TVOICE-009.02")) ;
+
+	iLine.NotifyStatusChange(iStatus2, lineStatus);
+	iLine.NotifyMobileLineStatusChange(iStatus3, mobileLineStatus);
+
+	User::WaitForRequest(iStatus2);
+	CHECKPOINT(iStatus2.Int(), KErrNone, _L("GT83-TVOICE-010.03")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-010.03")) ;
+
+	User::WaitForRequest(iStatus3);
+	CHECKPOINT(iStatus3.Int(), KErrNone, _L("GT83-TVOICE-031.08")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-031.08")) ;
+
+	TESTL(iStatus == KErrNone) ;
+	TESTL(iStatus2 == KErrNone) ;
+	TESTL(iStatus3 == KErrNone) ;
+	TESTL(iStatus4 == KErrNone) ;
+	TESTL(iStatus5 == KErrNone) ;
+#ifndef SIM_TSY
+	TESTL(iStatus6 == KErrNone) ;
+	TESTL(iStatus7 == KErrNone) ;
+#endif
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestLineStatusOutgoingCall::CTestLineStatusOutgoingCall()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestLineStatusOutgoingCall"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestLineStatusOutgoingCall::doTestStepL()
+/**	 Tests line status function
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-004.00 Test retrieval of a voice line's current status (Generic)
+ * @test GT83-TVOICE-004.01 "Test retrieval of a voice line's current status when the line's status is ""Unknown"""
+ * @test GT83-TVOICE-004.02 "Test retrieval of a voice line's current status when the line's status is ""Idle"""
+ * @test GT83-TVOICE-004.03 "Test retrieval of a voice line's current status when the line's status is ""Dialling"""
+ * @test GT83-TVOICE-004.07 "Test retrieval of a voice line's current status when the line's status is ""Connected"""
+ * @test GT83-TVOICE-004.08 "Test retrieval of a voice line's current status when the line's status is ""Hanging up"""
+ * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
+ * @test GT83-TVOICE-030.00 Test retrieval of a mobile voice line's current status (Generic)
+ * @test GT83-TVOICE-030.07 "Test retrieval of a mobile voice line's current status when there is only one call on the line and it's status is ""on hold"""
+ * @test GT83-TVOICE-031.01 Test setting a request for a notification of a change in the status of the mobile voice line
+*/
+	{
+	INFO_PRINTF1(_L("Test Line Status"));
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	RCall::TStatus lineStatus;
+    TName CallName ;
+	TBuf<16> GoodNumber ;
+	GetGoodNumber(GoodNumber) ;
+	// Open a Voice Line and Call
+	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	/* @test GT83-AT-36	Test retrieval of the current call status when it is idle*/
+	TInt ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
+
+	RMobileCall::TMobileCallStatus mobileLineStatus;
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-031.01")) ;
+	/* @test GT83-AT-028	Test opening a new call by specifying the name of a line
+	*/
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
+
+	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
+	iVoiceCall.Dial(iStatus, GoodNumber);
+
+	//doesn't work for MM.TSY
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	//CHECKPOINT(lineStatus, RCall::EStatusDialling, _L("GT83-TVOICE-004.03")) ;
+
+	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;
+	//Test for outgoing Voice Call
+	TestLineCapabilitiesL();
+
+	/* @test GT83-AT-36	Test retrieval of the current call status when it is connected*/
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.07")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.07")) ;
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-030.07")) ;
+
+
+	INFO_PRINTF1(_L("Please stay connected... the test will hang up shortly"));
+	User::After(10*KOneSecond);
+
+	INFO_PRINTF1(_L("Call connected - listen for 20 seconds..."));
+
+	User::After(20*KOneSecond); // hold call active for 20 seconds
+
+	INFO_PRINTF1(_L("Hanging up"));
+	iVoiceCall.HangUp(iStatus);
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-004.08")) ;
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA")) ;
+
+	//Test for outgoing Voice Call after hang up
+	TestLineCapabilitiesL();
+	/* @test GT83-AT-36	Test retrieval of the current call status when it is connected*/
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusIdle, _L("GT83-TVOICE-004.02")) ;
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-004.01")) ;
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestCallStatusOutgoingCall::CTestCallStatusOutgoingCall()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestCallStatusOutgoingCall"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestCallStatusOutgoingCall::doTestStepL()
+/**
+ * This function tests call status at various times during calls
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-009.01 Test setting notification of a change in hook status of a voice line
+ * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
+ * @test GT83-TVOICE-016.00 Test retrieval of the current call status (Generic)
+ * @test GT83-TVOICE-016.02 "Test retrieval of the current call status when the call's status is ""idle"""
+ * @test GT83-TVOICE-016.07 "Test retrieval of the current call status when the call's status is ""connected"""
+ * @test GT83-TVOICE-025.00 Test dialling a voice call (Generic)
+ * @test GT83-TVOICE-034.00 Test retrieval of the current status of the voice call (Generic)
+ * @test GT83-TVOICE-034.02 "Test retrieval of the current status of the voice call when the call's status is ""idle"""
+ * @test GT83-TVOICE-034.07 "Test retrieval of the current status of the voice call when the call's status is ""connected"""
+*/
+	{
+	// Get the Call Status
+	INFO_PRINTF1(_L("Get Call Status..."));
+	// Open a Voice Line and Call
+	INFO_PRINTF1(_L("Opening Voice Line"));
+
+	RCall::TStatus callStatus;
+	RMobileCall::TMobileCallStatus mobileCallStatus;
+    TName CallName ;
+
+	TBuf<16> GoodNumber ;
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	GetGoodNumber(GoodNumber) ;
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
+
+
+	TInt ret=iVoiceCall.GetStatus(callStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
+	TInt ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
+	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
+
+	if (ret==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Call Status is NOT Supported"));
+		}
+
+	if (ret2==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Mobile Call Status is NOT Supported"));
+		}
+
+	if ((ret==KErrNone) && (ret2==KErrNone))
+		{
+		CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.02")) ;
+		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.02")) ;
+		INFO_PRINTF1(_L("The call is Idle"));
+		}
+
+	// Now test call status during an outgoing call
+
+	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
+	iVoiceCall.Dial(iStatus, GoodNumber);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-025.00")) ;
+
+	ret=iVoiceCall.GetStatus(callStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
+	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
+	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
+
+	if ((ret==KErrNone) && (ret2==KErrNone))
+		{
+
+		Print_RCall_TStatus(callStatus) ;
+		CHECKPOINT(callStatus, RCall::EStatusConnected, _L("GT83-TVOICE-016.07")) ;
+		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-034.07")) ;
+		INFO_PRINTF1(_L("The call is Connected"));
+		}
+
+	INFO_PRINTF1(_L("Hanging up..."));
+
+	User::After(15*KOneSecond);
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-009.01")) ;
+
+	ret=iVoiceCall.GetStatus(callStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
+	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
+	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
+
+	if ((ret==KErrNone) && (ret2==KErrNone))
+		{
+		CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.02")) ;
+		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.02")) ;
+		INFO_PRINTF1(_L("The call is Idle again"));
+		}
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestCallStatusIncommingCall::CTestCallStatusIncommingCall()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestCallStatusIncommingCall"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestCallStatusIncommingCall::doTestStepL()
+/**
+ * This function tests call status at various times during calls
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-009.01 Test setting notification of a change in hook status of a voice line
+ * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
+ * @test GT83-TVOICE-016.00 Test retrieval of the current call status (Generic)
+ * @test GT83-TVOICE-016.02 "Test retrieval of the current call status when the call's status is ""idle"""
+ * @test GT83-TVOICE-016.04 "Test retrieval of the current call status when the call's status is ""ringing"""
+ * @test GT83-TVOICE-016.05 "Test retrieval of the current call status when the call's status is ""answering"""
+ * @test GT83-TVOICE-016.07 "Test retrieval of the current call status when the call's status is ""connected"""
+ * @test GT83-TVOICE-034.00 Test retrieval of the current status of the voice call (Generic)
+ * @test GT83-TVOICE-034.02 "Test retrieval of the current status of the voice call when the call's status is ""idle"""
+ * @test GT83-TVOICE-034.04 "Test retrieval of the current status of the voice call when the call's status is ""ringing"""
+ * @test GT83-TVOICE-034.05 "Test retrieval of the current status of the voice call when the call's status is ""answering"""
+ * @test GT83-TVOICE-034.07 "Test retrieval of the current status of the voice call when the call's status is ""connected"""
+ */
+	{
+	// Get the Call Status
+	INFO_PRINTF1(_L("Get Call Status..."));
+	// Open a Voice Line and Call
+	INFO_PRINTF1(_L("Opening Voice Line"));
+    TName CallName ;
+
+	RCall::TStatus callStatus;
+	RMobileCall::TMobileCallStatus mobileCallStatus;
+	TBuf<16> GoodNumber ;
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	GetGoodNumber(GoodNumber) ;
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
+
+
+	TInt ret=iVoiceCall.GetStatus(callStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
+	TInt ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
+	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
+
+	if (ret==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Call Status is NOT Supported"));
+		}
+
+	if (ret2==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Mobile Call Status is NOT Supported"));
+		}
+
+	if ((ret==KErrNone) && (ret2==KErrNone))
+		{
+		CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.02")) ;
+		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.02")) ;
+		INFO_PRINTF1(_L("The call is Idle"));
+		}
+
+	// Now test call status during an incomming call
+
+	// Wait for an incoming call, then get the Call BearerServiceInfo. The
+	// Bearer Service Info is only available if the call is currently active
+	INFO_PRINTF1(_L("Please ring the phone "));
+
+    TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
+	//User::After(1000000L);
+
+
+	/* GT83-AT-024	Test setting notification of an incoming call on a Voice Line */
+
+	//I had to comment these lines, because
+	// NotifyIncommigCall + AnswerIncommigCall doesn't work
+	//in such situation. Any way we can't get any good
+	//status without notifycation
+
+	//iLine.NotifyIncomingCall(iStatus, CallName);	// wait for a call
+	//WaitWithTimeout(iStatus,60*KOneSecond);				// but timeout after 60 seconds
+
+	//ret=iVoiceCall.GetStatus(callStatus);
+	//CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
+	//doesn't work for MM.TSY
+	//CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.01")) ;
+
+	//ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
+	//CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
+	//doesn't work for MM.TSY
+	//CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.01")) ;
+
+	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
+	iVoiceCall.AnswerIncomingCall(iStatus);
+	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 7 seconds
+
+	ret=iVoiceCall.GetStatus(callStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
+	//doesn't work for MM.TSY
+	//CHECKPOINT(callStatus, RCall::EStatusAnswering, _L("GT83-TVOICE-016.05")) ;
+
+	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
+	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
+	//doesn't work for MM.TSY
+	//CHECKPOINT(mobileCallStatus, RMobileCall::EStatusAnswering, _L("GT83-TVOICE-034.05")) ;
+	
+	ret=iVoiceCall.GetStatus(callStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
+	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
+	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
+
+	if ((ret==KErrNone) && (ret2==KErrNone))
+		{
+
+		Print_RCall_TStatus(callStatus) ;
+		CHECKPOINT(callStatus, RCall::EStatusConnected, _L("GT83-TVOICE-016.07")) ;
+		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-034.07")) ;
+		INFO_PRINTF1(_L("The call is Connected"));
+		}
+	INFO_PRINTF1(_L("Hanging up..."));
+
+	User::After(15*KOneSecond);
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-009.01")) ;
+
+	ret=iVoiceCall.GetStatus(callStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-016.00")) ;
+	ret2=iVoiceCall.GetMobileCallStatus(mobileCallStatus);
+	CHECKPOINT(ret2, KErrNone, _L("GT83-TVOICE-034.00")) ;
+
+	if ((ret==KErrNone) && (ret2==KErrNone))
+		{
+		CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TVOICE-016.02")) ;
+		CHECKPOINT(mobileCallStatus, RMobileCall::EStatusIdle, _L("GT83-TVOICE-034.02")) ;
+		INFO_PRINTF1(_L("The call is Idle again"));
+		}
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestLineInfo::CTestLineInfo()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestLineInfo"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestLineInfo::doTestStepL()
+/**
+ * This function gets the Line capabilities, line information, Number of calls
+ * on the line and call information,
+ * @test NONE	Test the ability to get the current line information of the Voice Line (Generic)
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-005.01 "Test retrieval of the current hook status, when the line is currently ""off hook"""
+ * @test GT83-TVOICE-005.02 "Test retrieval of the current hook status, when the line is currently ""on hook"""
+ * @test GT83-TVOICE-012.01 Test the ability to get the current line information of the voice line. Display the line information to screen.
+ * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
+ * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
+ * @test GT83-TVOICE-027.02 Test the ability to place an asynchronous request to hang up a voice call
+ */
+	{
+	INFO_PRINTF1(_L("Test Line Information"));
+	// Open a Voice Line and Call
+	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
+	TInt ret ;
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+    TName CallName ;
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
+
+	// Line Information
+	RLine::TLineInfo lineInfo;
+	TRAP(ret, ret=iLine.GetInfo(lineInfo));
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-012.01"));
+	if (ret!=KErrNone)
+		{
+		INFO_PRINTF1(_L("Get Line Info. is NOT supported"));
+		}
+	else
+		{
+		INFO_PRINTF1(_L("Get Line Info is successful"));
+		CHECKPOINT(lineInfo.iHookStatus,  RCall::EHookStatusOn, _L("GT83-TVOICE-0AAA")) ;
+		TESTL(lineInfo.iStatus == RCall::EStatusIdle) ;
+		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Name of last call added: %S")), &lineInfo.iNameOfLastCallAdded);
+		}
+
+	// Hook status information
+	INFO_PRINTF1(_L("Retrieving Hook Status..."));
+	RCall::THookStatus hookStatus;
+	ret=iLine.GetHookStatus(hookStatus);
+	if (ret!=KErrNone)
+		{
+		INFO_PRINTF1(_L("Get Hook status is NOT supported"));
+		}
+	else
+		{
+		CHECKPOINT(hookStatus, RCall::EHookStatusOn, _L("GT83-TVOICE-005.02")) ;
+		INFO_PRINTF1(_L("The line is currently ON Hook"));
+		}
+
+	INFO_PRINTF1(_L("Please ring the phone"));
+
+    TESTL(CallMeDear() == KErrNone) ; //init sim incoming call
+
+
+	// Answer an incoming call initiated  and obtain the call's current status
+	iVoiceCall.AnswerIncomingCall(iStatus);
+
+	WaitWithTimeout(iStatus,2*KTenSeconds);		// but timeout after 60 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
+
+	// Count the no. of calls on the line & Get call info.
+	INFO_PRINTF1(_L("Retrieving no. of calls opened from the line.."));
+	TInt lineCount=0;
+	iLine.EnumerateCall(lineCount);
+	INFO_PRINTF2(TRefByValue<const TDesC>(_L("No of calls opened = %d")), lineCount);
+
+	//doesn't work for MM.TSY
+	INFO_PRINTF1(_L("Getting Call info.."));
+	RLine::TCallInfo callInfo;
+	ret=iLine.GetCallInfo(0,callInfo);
+	//doesn't work for MM.TSY
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-007.01"));
+
+	if (ret==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Call information is NOT supported"));
+		}
+	if (ret==KErrNone)
+		{
+		INFO_PRINTF1(_L("Get Call information is successful"));
+		}
+
+	// Get the line's current hook status
+	ret=iLine.GetHookStatus(hookStatus);
+	if (ret!=KErrNone)
+		{
+		INFO_PRINTF1(_L("Get Hook status is NOT supported"));
+		}
+	else
+		{
+		CHECKPOINT(hookStatus, RCall::EHookStatusOff, _L("GT83-TVOICE-005.01")) ;
+		INFO_PRINTF1(_L("The line is currently OFF Hook"));
+		}
+
+	INFO_PRINTF1(_L("Please stay connected... the test will hang up shortly"));
+	User::After(KTenSeconds);
+
+	INFO_PRINTF1(_L("Hanging up"));
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-027.02")) ;
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestCallCancels::CTestCallCancels()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestCallCancels"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestCallCancels::doTestStepL()
+/**
+ * This function posts and then cancels Call Notifications.
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
+ * @test GT83-TVOICE-018.01 Test setting notification of a change in the call's capabilities
+ * @test GT83-TVOICE-018.03 Test the ability to cancel a notification of a change in the call's capabilities
+ * @test GT83-TVOICE-020.01 Test setting notification of a change in hook status of a voice call
+ * @test GT83-TVOICE-020.04 Test the ability to cancel a notification of a change in hook status of a voice call
+ * @test GT83-TVOICE-021.01 Test setting notification of a change in the status of the voice call
+ * @test GT83-TVOICE-022.01 Test setting notification of a change in the voice call's duration
+ * @test GT83-TVOICE-022.03 Test cancelling notification of a change in the voice call's duration
+*/
+	{
+	INFO_PRINTF1(_L("Test Call Cancels"));
+	// Open a Voice Line and Call
+	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+    TName CallName ;
+    INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
+
+	// Call Status Change Cancel Request
+	RCall::TStatus callStatus;
+	iVoiceCall.NotifyStatusChange(iStatus, callStatus);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-021.01")) ;
+	User::After(KTenPartOfSec); //snack some sleep
+	iVoiceCall.NotifyStatusChangeCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-021.04")) ;
+
+#if 0  //cancel functions don't work yet (?)
+	   //any way they are not declared 27.09.2001
+	RMobileCall::TMobileCallStatus mobileCallStatus;
+	iiVoiceCall.NotifyMobileCallStatusChange(iStatus, mobileCallStatus);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-0AAA")) ;
+	iiVoiceCall.NotifyMobileCallStatusChangeCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-0AAA")) ;
+#endif
+	// Hook Change Cancel Request
+	RCall::THookStatus hookStatus;
+	iVoiceCall.NotifyHookChange(iStatus, hookStatus);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-020.01")) ;
+	User::After(KTenPartOfSec); //snack some sleep
+	iVoiceCall.NotifyHookChangeCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-020.04")) ;
+
+	// Test Cancelling Notifications
+	RCall::TCaps callCaps;
+	iVoiceCall.NotifyCapsChange(iStatus, callCaps);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-018.01")) ;
+	User::After(KTenPartOfSec); //snack some sleep
+	iVoiceCall.NotifyCapsChangeCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-018.03")) ;
+
+#if 0  //cancel functions don't work yet (?)
+	   //any way they are not declared 27.09.2001
+	RMobileCall::TMobileCallCapsV1 mobileCallCaps;
+	RMobileCall::TMobileCallCapsV1Pckg mobileCallCapsPckg(mobileCallCaps);
+	iVoiceCall.NotifyMobileCallCapsChange(iStatus, mobileCallCapsPckg);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-0AAA")) ;
+	iVoiceCall.NotifyMobileCallCapsChangeCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-0AAA")) ;
+
+
+	TTimeIntervalSeconds callDuration;
+	iVoiceCall.NotifyCallDurationChange(iStatus, callDuration);
+	CHECKPOINT((iStatus==KRequestPending || iStatus==KErrNotSupported), 1, _L("GT83-TVOICE-022.01")) ;
+	User::After(KTenPartOfSec); //snack some sleep
+	iVoiceCall.NotifyCallDurationChangeCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNotSupported, _L("GT83-TVOICE-022.03")) ;		// AMC - the SIM TSY does not support duration notifications...
+#endif
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestLineCancels::CTestLineCancels()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestLineCancels"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestLineCancels::doTestStepL()
+/**
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-008.01 Test setting notification of an incoming call on a voice line
+ * @test GT83-TVOICE-008.03 Test the ability to cancel the notification of an incoming call on a voice line
+ * @test GT83-TVOICE-009.01 Test setting notification of a change in hook status of a voice line
+ * @test GT83-TVOICE-009.04 Test the ability to cancel a notification of a change in hook status of a voice line
+ * @test GT83-TVOICE-010.04 Test the ability to cancel the notification of a change in the status of the voice line
+ * @test GT83-TVOICE-011.01 Test setting notification of a call being added to a voice line
+ * @test GT83-TVOICE-011.05 Test the ability to cancel a notification of a call being added to a voice line
+ */
+	{
+	INFO_PRINTF1(_L("Test Line Cancels"));
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	// Notify Incoming Call
+	TName callName;
+	//GT83-AT-021	Test opening a Voice Line from a phone that supports data functionality
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	iLine.NotifyIncomingCall(iStatus, callName);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-008.01")) ;
+	User::After(KTenPartOfSec); //snack some sleep
+	iLine.NotifyIncomingCallCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-008.03")) ;
+
+	// Notify Status Change
+	RCall::TStatus lineStatus;
+	iLine.NotifyStatusChange(iStatus, lineStatus);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-010.02")) ;
+	User::After(KTenPartOfSec); //snack some sleep
+	iLine.NotifyStatusChangeCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-010.04")) ;
+
+#if 0  //cancel functions don't work yet (?)
+	   //any way they are not declared 27.09.2001
+	// Notify Mobile Status Change
+	RMobileCall::TMobileCallStatus lineStatus2;
+	iLine.NotifyMobileLineStatusChange(iStatus, lineStatus2);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-0AAA")) ;
+	iLine.NotifyMobileLineStatusChangeCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-0AAA")) ;
+#endif
+	// Notify Hook Change
+	RCall::THookStatus hookStatus;
+	iLine.NotifyHookChange(iStatus, hookStatus);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-009.01")) ;
+	User::After(KTenPartOfSec); //snack some sleep
+	iLine.NotifyHookChangeCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-009.04")) ;
+
+	// Notify Call Added
+	iLine.NotifyCallAdded(iStatus, callName);
+	CHECKPOINT(iStatus.Int(), KRequestPending, _L("GT83-TVOICE-011.01")) ;
+	User::After(KTenPartOfSec); //snack some sleep
+	iLine.NotifyCallAddedCancel();
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrCancel, _L("GT83-TVOICE-011.05")) ;
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestMoreCallInfo::CTestMoreCallInfo()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestMoreCallInfo"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestMoreCallInfo::doTestStepL()
+/**
+ * This function gets more information pertaining to a Voice Call: Call ownership,
+ * Call parameters, Loan data port requests and Transfer ownership requests.
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
+ * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
+ * @test GT83-TVOICE-028.01 Test the ability to make a request to acquire the ownership of a call
+ * @test GT83-TVOICE-029.01 Test transferring the call ownership when another client has requested to acquire call ownership
+ */
+	{
+	INFO_PRINTF1(_L("More Call Information Tests"));
+	TInt ret ;
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+    TName callName;
+	RCall::TStatus lineStatus;
+
+	// my cases I start
+
+	//RCall::TStatus callStatus;	
+	RMobileCall::TMobileCallStatus mobileCallStatus;	
+	TRequestStatus reqStatus0;
+	RMobileCall spareCall;
+	CleanupClosePushL(spareCall);
+
+	// case 1 start
+	iLine.NotifyIncomingCall(iStatus, callName);	// wait for a call
+	TESTL(CallMeDear() == KErrNone) ;		
+	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.02")) ;
+	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
+
+
+	ret = spareCall.OpenExistingCall(iLine, callName);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
+
+	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
+	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
+	spareCall.AnswerIncomingCall(iStatus);
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 2 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.04")) ;
+	spareCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus); 
+	CleanupStack::Pop(&spareCall);
+	spareCall.Close();
+	// case 1 end
+
+	// case 2 start
+	TBuf<16> GoodNumber ;
+	GetGoodNumber(GoodNumber) ;
+
+	RMobileCall voiceCall4;
+	CHECKPOINT(ret=voiceCall4.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-014.05"));
+	voiceCall4.Dial(iStatus,GoodNumber);
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 7 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));	
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.04")) ;
+
+
+	iLine.NotifyIncomingCall(iStatus, callName);	// wait for a call
+
+	TESTL(CallMeDear() == KErrNone); 		// AMC - Added
+	WaitWithTimeout(iStatus,15*KOneSecond);				// but timeout after 60 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-008.02")) ;
+	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusRinging, _L("GT83-TVOICE-004.04")) ;
+
+	ret = spareCall.OpenExistingCall(iLine, callName);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-015.05")) ;
+	
+	CleanupClosePushL(spareCall);
+	
+	voiceCall4.Hold(iStatus);
+	User::WaitForRequest(iStatus);
+	TEST(iStatus==KErrNone);
+	TEST(voiceCall4.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusHold);
+
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusRinging, _L("GT83-TVOICE-004.04")) ;
+	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
+	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
+	spareCall.AnswerIncomingCall(iStatus);
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 7 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
+	ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-004.00")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusConnected, _L("GT83-TVOICE-004.04")) ;
+	spareCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus); 
+	CleanupStack::Pop(&spareCall);
+	spareCall.Close();
+	voiceCall4.Close();
+	// case 2 end
+	// my cases I end
+
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-014.05"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
+
+	// Wait for an incoming Call
+	INFO_PRINTF1(_L("Please ring the phone"));
+
+    iVoiceCall.AnswerIncomingCall(iStatus);		// set as an answering phone
+	TESTL(CallMeDear() == KErrNone)  ;          // init sim incoming call 
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 15 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
+
+	// Retrieve Call Ownership information
+	INFO_PRINTF1(_L("Get Call Ownership.."));
+	RCall::TOwnershipStatus callOwner;
+	ret=iVoiceCall.GetOwnershipStatus(callOwner);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-026.01"));
+
+	if (ret==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Call OwnerShip is NOT Supported"));
+		}
+
+	if (ret==KErrNone)
+		{
+		INFO_PRINTF1(_L("Get Call OwnerShip is Supported"));
+
+		switch(callOwner)
+			{
+			case RCall::EOwnershipUnowned:
+				INFO_PRINTF1(_L("The call is unowned"));
+				break;
+			case RCall::EOwnershipOwnedByAnotherClient:
+				INFO_PRINTF1(_L("The call is owned by another Client"));
+				break;
+			case RCall::EOwnershipOwnedByThisClient:
+				INFO_PRINTF1(_L("The call is owned by this client"));
+				break;
+			default:
+				INFO_PRINTF1(_L("Error in Call Ownership details"));
+				break;
+			}
+		}
+
+	// Call Parameters
+	INFO_PRINTF1(_L("Get Call Parameters..."));
+	RCall::TCallParams callParams;
+	RCall::TCallParamsPckg callParamsPckg(callParams);
+	ret=iVoiceCall.GetCallParams(callParamsPckg);
+#ifndef SIM_TSY
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-0AAA"));
+#endif
+	if (ret==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Call Parameters is NOT Supported"));
+		}
+	if (ret==KErrNone)
+		{
+		INFO_PRINTF1(_L("Get Call Parameters is successful"));
+		}
+	
+	// Post a 'New call added' notification
+	iLine.NotifyCallAdded(iStatus, callName);
+
+	// Open a 2nd Voice Call, see BeginTest() function for explanatory comments
+	INFO_PRINTF1(_L("Opening another Voice Call"));
+	
+	RMobileCall voiceCall2;
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(ret=voiceCall2.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-014.05"));
+	CleanupClosePushL(voiceCall2);
+	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
+
+	if(ret == KErrNone)
+		{
+		INFO_PRINTF1(_L("2nd Voice Call opened successfully"));
+		}
+
+	if(ret == KErrNotSupported) //we don't have anything to do, bye...
+		{
+		User::WaitForRequest(iStatus);  // Notify Call added completion
+
+
+		INFO_PRINTF1(_L("2nd Voice Call are not supported"));
+		INFO_PRINTF1(_L("Hanging up"));
+		iVoiceCall.HangUp(iStatus);
+		User::WaitForRequest(iStatus);
+
+		CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-0AAA"));
+		INFO_PRINTF1(_L("HangUp successful"));
+		// Close the line and call
+		CleanupStack::PopAndDestroy(&voiceCall2) ;
+		CleanupStack::PopAndDestroy(&iVoiceCall);
+		CleanupStack::PopAndDestroy(&iLine);
+		return TestStepResult();
+		}
+
+	User::WaitForRequest(iStatus);  // Notify Call added completion
+	if (iStatus==KErrNone)
+		{
+		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Notify Call added status = %d")), iStatus.Int());
+		}
+
+	// my cases II start
+
+
+	// 3rd case put 1st on hold, dial on other
+
+	iVoiceCall.Hold(reqStatus0);
+	User::WaitForRequest(reqStatus0);
+	TEST(reqStatus0==KErrNone);
+	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusHold);
+
+	// Now test call status during an outgoing call
+	
+	INFO_PRINTF2(_L("Dialling %S...."), &GoodNumber);
+	voiceCall2.Dial(iStatus, GoodNumber);			
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 7 seconds
+	TEST(voiceCall2.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
+
+	INFO_PRINTF1(_L("Call connected - now hanging up..."));
+	voiceCall2.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-020.01"));	
+
+
+	iVoiceCall.Resume(reqStatus0);
+	User::WaitForRequest(reqStatus0);
+	TEST(reqStatus0==KErrNone);
+	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
+
+	// 4th case put 1st on hold, answer on other
+
+	iVoiceCall.Hold(reqStatus0);
+	User::WaitForRequest(reqStatus0);
+	TEST(reqStatus0==KErrNone);
+	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusHold);
+
+	RMobileCall::TMobileCallStatus mobileLineStatus;
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusHold, _L("GT83-TVOICE-031.01")) ;
+
+
+	voiceCall2.AnswerIncomingCall(iStatus);		// set as an answering phone
+	TESTL(CallMeDear() == KErrNone)  ;          // init sim incoming call 
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 15 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
+	// now hangup call
+
+	INFO_PRINTF1(_L("Call connected - now hanging up..."));
+	voiceCall2.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusHold, _L("GT83-TVOICE-031.01")) ;
+
+	iVoiceCall.Resume(reqStatus0);
+	User::WaitForRequest(reqStatus0);
+	TEST(reqStatus0==KErrNone);
+	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
+
+
+	// 5th case put 1st on hold, answer on other
+
+	RCall::TCaps callCaps;
+ 	ret=iVoiceCall.GetCaps(callCaps);
+ 	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
+	TEST(callCaps.iFlags & RCall::KCapsVoice );
+	TEST(callCaps.iFlags & RMobileCall::KCapsHold) ;
+	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
+
+	iVoiceCall.Hold(reqStatus0);
+	User::WaitForRequest(reqStatus0);
+	TEST(reqStatus0==KErrNone);
+	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusHold);	
+
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusHold, _L("GT83-TVOICE-031.01")) ;
+
+
+	iVoiceCall.Swap(reqStatus0);
+	User::WaitForRequest(reqStatus0);
+	TEST(reqStatus0==KErrNone);
+	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
+
+	iVoiceCall.Swap(reqStatus0);
+	User::WaitForRequest(reqStatus0);
+	TEST(reqStatus0==KErrNone);
+	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusHold);
+
+	ret=iVoiceCall.GetCaps(callCaps);
+	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
+	TEST(callCaps.iFlags & RCall::KCapsVoice );
+	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
+	TEST(callCaps.iFlags & RMobileCall::KCapsResume) ;
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusHold, _L("GT83-TVOICE-031.01")) ;
+
+	voiceCall2.AnswerIncomingCall(iStatus);		// set as an answering phone
+	TESTL(CallMeDear() == KErrNone)  ;          // init sim incoming call 
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 15 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
+	TEST(voiceCall2.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
+
+	ret=voiceCall2.GetCaps(callCaps);
+	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
+	TEST(callCaps.iFlags & RCall::KCapsVoice );
+	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
+	TEST(!(callCaps.iFlags & RMobileCall::KCapsHold)) ;
+
+	ret=iVoiceCall.GetCaps(callCaps);
+	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
+	TEST(callCaps.iFlags & RCall::KCapsVoice );
+	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
+	TEST(!(callCaps.iFlags & RMobileCall::KCapsResume)) ;
+	
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
+
+
+	voiceCall2.Swap(iStatus);
+	User::WaitForRequest(iStatus);	
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
+
+	TEST(voiceCall2.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusHold);
+	
+	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
+
+	ret = iLine.GetMobileLineStatus(mobileLineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-030.00")) ;
+	CHECKPOINT(mobileLineStatus, RMobileCall::EStatusConnected, _L("GT83-TVOICE-031.01")) ;
+
+
+	// try to activate call on hold whilst other is connected
+	iVoiceCall.Swap(iStatus);
+	User::WaitForRequest(iStatus);	
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
+
+	TEST(voiceCall2.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusConnected);
+
+	
+	TEST(iVoiceCall.GetMobileCallStatus(mobileCallStatus)==KErrNone);
+	TEST(mobileCallStatus==RMobileCall::EStatusHold);
+
+	
+	// try to dial whilst have 2 active
+	
+	RMobileCall voiceCall3;
+	CHECKPOINT(ret=voiceCall3.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-014.05"));
+	CleanupClosePushL(voiceCall3);
+	voiceCall3.Dial(iStatus,GoodNumber);
+	User::WaitForRequest(iStatus);	
+	CHECKPOINT(iStatus.Int(), KErrGeneral, _L("GT83-TVOICE-026.00"));
+	voiceCall3.Close();
+	CleanupStack::Pop(&voiceCall3);
+
+	// try to activate call 
+	iVoiceCall.Swap(iStatus);
+	User::WaitForRequest(iStatus);	
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00"));
+
+	// now hangup call
+
+	INFO_PRINTF1(_L("Call connected - now hanging up..."));
+	ret=iVoiceCall.GetCaps(callCaps);
+	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
+	TEST(callCaps.iFlags & RCall::KCapsVoice );
+	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
+	TEST(!(callCaps.iFlags & RMobileCall::KCapsHold)) ;
+
+	voiceCall2.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+
+	ret=iVoiceCall.GetCaps(callCaps);
+	CHECKPOINT(ret,KErrNone,_L("GT83-TVOICE-031.01"));
+	TEST(callCaps.iFlags & RCall::KCapsVoice );
+	TEST(callCaps.iFlags & RMobileCall::KCapsSwap) ;
+	TEST(callCaps.iFlags & RMobileCall::KCapsHold) ;
+		
+
+	//Close the 2nd Voice Call
+	voiceCall2.Close();
+	CleanupStack::Pop(&voiceCall2) ;
+	INFO_PRINTF1(_L("Closing the 2nd Voice Call"));
+
+	// my II cases end	
+
+	// Hang up the Call
+	INFO_PRINTF1(_L("Hanging up"));
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-029.02"));
+	INFO_PRINTF1(_L("HangUp successful"));
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestCallInfo::CTestCallInfo()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestCallInfo"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestCallInfo::doTestStepL()
+/**
+ * This function gets information pertaining to a call:
+ * Bearer Service Information, Call duration, Remote Party Information (if available)
+ * @test GT83-TVOICE-001.01 "Test opening a voice line, specifying the phone that should be used"
+ * @test GT83-TVOICE-009.02 "Test notification of a change in hook status of a voice line from ""off"" to ""on"""
+ * @test GT83-TVOICE-014.05 "Test opening a new call by specifying the name of a line, and displaying the name of the new call"
+ * @test GT83-TVOICE-019.01 "Test retrieval of the bearer service info of a call. Display to screen, all the bearer service information associated with the call."
+ * @test GT83-TVOICE-023.01 Test retrieval of the duration of a voice call. Display the call duration to screen
+ * @test GT83-TVOICE-024.01 Test the ability to get the current call information of the voice call. Display the call information to screen.
+ * @test GT83-TVOICE-026.00 Test answering a call on a voice line (Generic)
+ * @test GT83-TVOICE-036.01 Test retreival of the call information and print the call information to screen.
+*/
+	{
+	INFO_PRINTF1(_L("Test Call Information"));
+	RMobileCall::TMobileCallInfoV1 mobileCallInfo;
+	RMobileCall::TMobileCallInfoV1Pckg mobileCallInfoPckg(mobileCallInfo) ;
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-001.01"));
+
+	TName CallName ;
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("GT83-TVOICE-014.05"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
+
+	//get status
+	RCall::TStatus callStatus;
+	CHECKPOINT(iVoiceCall.GetStatus(callStatus), KErrNone, _L("GT83-TD-016.02")) ;
+	CHECKPOINT(callStatus, RCall::EStatusIdle, _L("GT83-TD-016.02")) ;
+
+	INFO_PRINTF2(_L("Call Status = %d"), callStatus);
+	Print_RCall_TStatus(callStatus) ;
+	// Wait for an incoming call, then get the Call BearerServiceInfo. The
+	// Bearer Service Info is only available if the call is currently active
+	INFO_PRINTF1(_L("Please ring the phone"));
+
+    TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
+
+
+	// Answer an incoming call initiated by t_echo.exe and obtain the call's current status
+	//GT83-AT-032	Test answering a call on a Voice Line (Generic)	RCall::AnswerIncomingCall
+	iVoiceCall.AnswerIncomingCall(iStatus);
+	WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 60 seconds
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-026.00")) ;
+
+	// User Information
+	INFO_PRINTF1(_L("The call is now connected."));
+	INFO_PRINTF1(_L("Retrieving Call Information."));
+
+	// Bearer Service Information
+	INFO_PRINTF1(_L("Get Bearer Service Info..."));
+	RCall::TBearerService bearerServiceInfo;
+	TInt ret=iVoiceCall.GetBearerServiceInfo(bearerServiceInfo);
+	CHECKPOINT(ret, KErrNotSupported, _L("GT83-TVOICE-019.01")) ;
+	INFO_PRINTF1(_L("Get BearerService Information is NOT Supported"));
+
+	// Get Call Information
+	INFO_PRINTF1(_L("Get Current Call Info..."));
+	ret=iVoiceCall.GetInfo(iCallInfo);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-024.01")) ;
+	if (ret==KErrNone)
+		{
+		INFO_PRINTF1(_L("Displaying Information about the Current Call"));
+		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call name: %S")), &iCallInfo.iCallName);
+		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Line name: %S")), &iCallInfo.iLineName);
+		if (iCallInfo.iHookStatus==RCall::EHookStatusOff)
+			{
+			INFO_PRINTF1(_L("Current Hook Status: Off"));
+			}
+		if (iCallInfo.iStatus==RCall::EStatusConnected)
+			{
+			INFO_PRINTF1(_L("Current Call Status: Connected"));
+			}
+		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call Duration: %d seconds")), iCallInfo.iDuration.Int());
+		}
+
+	INFO_PRINTF1(_L("Get Current Mobile Call Info..."));
+	ret=iVoiceCall.GetMobileCallInfo(mobileCallInfoPckg);
+
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-036.01")) ;
+	if (ret==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Current Call info is NOT Supported"));
+		}
+
+	//Get Remote Party Info (PDEF108459)
+ 	RMobileCall::TMobileCallRemotePartyInfoV1 remoteParty;
+ 	RMobileCall::TMobileCallRemotePartyInfoV1Pckg remotePartyPckg(remoteParty);	
+ 	
+ 	TRequestStatus reqStatus;
+ 	iVoiceCall.NotifyRemotePartyInfoChange(reqStatus, remotePartyPckg);
+ 	User::WaitForRequest(reqStatus);	
+ 	
+ 	TESTL(reqStatus == KErrNone);
+ 	
+ 	if (remoteParty.iRemoteIdStatus == RMobileCall::ERemoteIdentityAvailable)
+ 		{			
+ 		INFO_PRINTF1(_L("Displaying Remote Party Information about the Current Call"));
+ 		_LIT(KCallingName, "Calling Name : %S");
+ 		INFO_PRINTF2(KCallingName, &remoteParty.iCallingName);
+ 		_LIT(KRemoteNumber, "Remote Number : %S");
+ 		INFO_PRINTF2(KRemoteNumber, &remoteParty.iRemoteNumber.iTelNumber);
+   		}
+	else
+		{
+		_LIT(KRemoteIdentityNotAvilable,"Remote Identity is not available.");
+ 		INFO_PRINTF1(KRemoteIdentityNotAvilable);
+   		}
+
+	// Hang up the Call
+	INFO_PRINTF1(_L("Please stay connected... the test will hang up shortly"));
+	User::After(5*KOneSecond);
+
+	// Call Duration
+	INFO_PRINTF1(_L("Get Call Duration..."));
+	TTimeIntervalSeconds callDuration2;
+	ret=iVoiceCall.GetCallDuration(callDuration2);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-023.01")) ;
+
+	if (ret==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Current Call Duration is NOT Supported"));
+		}
+	if (ret==KErrNone)
+		{
+		INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), callDuration2.Int());
+		}
+
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("GT83-TVOICE-009.02")) ;
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestPhoneInfo::CTestPhoneInfo()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestPhoneInfo"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestPhoneInfo::doTestStepL()
+/**
+ * This function retrieves a snapshot of the phone's GSM information, gets the
+ * number of lines associated with the phone as well as information on the line
+ * and phone. Gets the phone's status and also performs some Cancel Requests.
+ * @test GT83-TVOICE-037.01	Retrieve phone's multimode capabilities and print them to screen.
+ */
+	{
+	INFO_PRINTF1(_L("Phone Information test"));
+
+	// Retrieve a snapshot of the current phone information
+	INFO_PRINTF1(_L("Get Phone Info..."));
+	RPhone::TPhoneInfo phoneInfo;
+	RPhone::TCaps phoneCaps;
+	TInt ret=iPhone.GetInfo(phoneInfo);
+	if (ret==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Phone info is NOT Supported"));
+		}
+	if (ret==KErrNone)
+		{
+		INFO_PRINTF1(_L("Get Phone Info is successful."));
+		CHECKPOINT(phoneInfo.iDetection, RPhone::EDetectedPresent, _L("GT83-TVOICE-0AAA"));
+		INFO_PRINTF1(_L("Local Modem has been detected."));
+		}
+
+	//test mobile phone caps
+	RMobilePhone::TMobilePhoneModeCaps mobileCaps ;
+	CHECKPOINT(iPhone.GetMultimodeCaps((TUint32&)mobileCaps), KErrNone, _L("GT83-TVOICE-037.01")) ;
+	Print_TMobilePhoneModeCaps(mobileCaps);
+
+	// Number of lines associated with the phone
+	TInt lineCount=0;
+	TESTL(iPhone.EnumerateLines(lineCount)==KErrNone);
+	TESTL(lineCount>0);
+
+	for (;lineCount>0; lineCount--)
+		{
+		CHECKPOINT(iPhone.GetLineInfo(lineCount-1, iLineInfo), KErrNone, _L("GT83-TVOICE-0AAA"));
+		INFO_PRINTF4(_L("Line %d (%S) cap flags = 0x%x"),
+			lineCount-1, &iLineInfo.iName,iLineInfo.iLineCapsFlags);
+		if (iLineInfo.iLineCapsFlags&RLine::KCapsVoice)
+			{
+			INFO_PRINTF3(_L("Line %d (%S) has voice capability"), lineCount-1, &iLineInfo.iName);
+			iLineIndex=lineCount-1;
+			break;
+			}
+		}
+	TESTL(lineCount>0);
+
+	// Status of the Phone
+	INFO_PRINTF1(_L("Get the Phone's Status..."));
+	RPhone::TStatus phoneStatus;
+	ret=iPhone.GetStatus(phoneStatus);
+	if (ret==KErrNotSupported)
+		{
+		INFO_PRINTF1(_L("Get Phone Status is NOT Supported"));
+		}
+	if (ret==KErrNone)
+		{
+		INFO_PRINTF1(_L("Get Phone Status is successful."));
+		CHECKPOINT(phoneStatus.iMode, RPhone::EModeIdle, _L("GT83-TVOICE-0AAA"));
+		INFO_PRINTF1(_L("The phone is currently Idle"));
+		}
+
+	// Notification Cancel Requests : Modem Detected
+	INFO_PRINTF1(_L("Notify Modem Detected Cancel Request..."));
+	RPhone::TModemDetection detected;
+	iPhone.NotifyModemDetected(iStatus, detected);
+	iPhone.NotifyModemDetectedCancel();
+	User::WaitForRequest(iStatus);
+	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Notify Modem Detected Cancel status: %d")), iStatus.Int());
+
+	// Notification Cancel Requests : Caps Change
+	INFO_PRINTF1(_L("Notify Caps Change Cancel Request..."));
+	iPhone.NotifyCapsChange(iStatus, phoneCaps);
+	iPhone.NotifyCapsChangeCancel();
+	User::WaitForRequest(iStatus);
+	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Notify Caps Change Cancel status: %d")), iStatus.Int());
+	return TestStepResult();
+	}
+//------------------------------------------------------------------
+
+CTestDtmf::CTestDtmf()
+/** Each test step i7nitialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestDtmf"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestDtmf::doTestStepL()
+/** DTMF tests suite
+ * @test GT83-TVOICE-038.01 Test retieval of DTMF capabilities where the TSY/ME supports sending a string of DTMF tones, containing one or more tone(s).
+ * @test GT83-TVOICE-040.02 Test sending a valid string of DTMF tone characters (p,0,1,2,3,4,5,6,7,8,9,0,w,A,B,C,D,*,#)
+ * @test GT83-TVOICE-041.00 Test sending a single DTMF tone (Generic)
+ * @test GT83-TVOICE-042.01 Test setting a request for a notification of a stop in a DTMF string
+ * @test GT83-TVOICE-042.03 Test the ability to continue sending tones when a stop is encountered in the middle of a DTMF string
+*/
+	{
+	_LIT(KDtmfString0,"45p6789ABCDp");
+	_LIT(KDtmfString1,"01w23");
+
+	//to make sure that line and call will be closed in leave case
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	TESTL(iLine.Open(iPhone,KVoiceLineName)==KErrNone);
+	INFO_PRINTF1(_L("Opened Line object"));
+
+	TName callName;
+	TESTL(iVoiceCall.OpenNewCall(iLine,callName)==KErrNone);
+	INFO_PRINTF1(_L("Opened Call object"));
+
+	TRequestStatus reqStatus0, reqStatus1;
+
+	INFO_PRINTF2(_L("Dialling %S "),&KGoodNumber);
+	iVoiceCall.Dial(reqStatus0,KGoodNumber);
+	User::WaitForRequest(reqStatus0);
+	// Wait for the Call Status Change notification
+	TESTL(reqStatus0==KErrNone);
+	INFO_PRINTF1(_L("...Call is Connected"));
+
+	INFO_PRINTF1(_L("Testing an erroneous DTMF String Tx Continue"));
+	TESTL(iPhone.ContinueDTMFStringSending(ETrue)==KErrNotReady);
+
+	INFO_PRINTF1(_L("Test DTMF Caps"));
+	TUint32 dtmfCaps;
+	CHECKPOINT(iPhone.GetDTMFCaps(dtmfCaps), KErrNone, _L("GT83-TVOICE-038.01"));
+	TESTL(((dtmfCaps &(RMobilePhone::KCapsSendDTMFString
+				   | RMobilePhone::KCapsSendDTMFSingleTone)) !=0) );
+
+	INFO_PRINTF1(_L("Test Send DTMF String"));
+	iPhone.SendDTMFTones(reqStatus0,KDtmfString0) ;
+	User::After(1000000);
+
+	TChar character('1');
+	CHECKPOINT(iPhone.StartDTMFTone(character), KErrInUse, _L("GT83-TVOICE-041.00"));
+	User::After(1000000);
+	CHECKPOINT(iPhone.StopDTMFTone(), KErrInUse, _L("GT83-TVOICE-040.09"));
+	User::WaitForRequest(reqStatus0);
+	TESTL(reqStatus0==KErrNone);
+
+	INFO_PRINTF1(_L("Test Start & Stop DTMF Tone"));
+	CHECKPOINT(iPhone.StartDTMFTone(character), KErrNone, _L("GT83-TVOICE-041.00"));
+	User::After(1000000);
+	CHECKPOINT(iPhone.StopDTMFTone(), KErrNone, _L("GT83-TVOICE-040.09"));
+
+	INFO_PRINTF1(_L("Test Send DTMF String with wait & continue"));
+	iPhone.NotifyStopInDTMFString(reqStatus1);
+
+	iPhone.SendDTMFTones(reqStatus0,KDtmfString1);
+	CHECKPOINT(reqStatus0.Int(), KRequestPending, _L("GT83-TVOICE-040.02"));
+	User::WaitForRequest(reqStatus1);
+	TESTL(reqStatus1==KErrNone);
+	CHECKPOINT(iPhone.ContinueDTMFStringSending(ETrue), KErrNone, _L("GT83-TVOICE-042.03"));
+	User::WaitForRequest(reqStatus0);
+	TESTL(reqStatus0==KErrNone);
+
+	INFO_PRINTF1(_L("Test Send DTMF String with wait & terminate"));
+	iPhone.NotifyStopInDTMFString(reqStatus1);
+	CHECKPOINT(reqStatus1.Int(), KRequestPending,_L("GT83-TVOICE-042.01"));
+	iPhone.SendDTMFTones(reqStatus0,KDtmfString1);
+	CHECKPOINT(reqStatus0.Int(), KRequestPending,_L("GT83-TVOICE-040.02"));
+	User::WaitForRequest(reqStatus1);
+	TESTL(reqStatus1==KErrNone);
+	CHECKPOINT(iPhone.ContinueDTMFStringSending(EFalse), KErrNone, _L("GT83-TVOICE-042.03"));
+	User::WaitForRequest(reqStatus0);
+	TESTL(reqStatus0==KErrAccessDenied);
+
+	INFO_PRINTF1(_L("Test Send DTMF String terminated early by a call closure"));
+	iPhone.SendDTMFTones(reqStatus0,KDtmfString0);
+	CHECKPOINT(reqStatus0.Int(), KRequestPending,_L("GT83-TVOICE-040.02"));
+	User::After(1000000);
+	INFO_PRINTF1(_L("Hanging up..."));
+	TESTL(iVoiceCall.HangUp()==KErrNone);
+	User::WaitForRequest(reqStatus0);
+	TESTL(reqStatus0==KErrEtelNoCarrier);
+
+	INFO_PRINTF1(_L("Test Sending DTMF Strings while there is no active call."));
+	CHECKPOINT(iPhone.ContinueDTMFStringSending(ETrue), KErrNotReady, _L("GT83-TVOICE-042.03"));
+	iPhone.SendDTMFTones(reqStatus0,KDtmfString0);
+	User::WaitForRequest(reqStatus0);
+	TESTL(reqStatus0==KErrEtelCallNotActive);
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+	}
+
+//------------------------------------------------------------------
+
+CTestRemoteHangup::CTestRemoteHangup()
+/** Each test step initialises it's own name
+*/
+	{
+	// store the name of this test case
+	// this is the name that is used by the script file
+	SetTestStepName(_L("TestRemoteHangup"));
+	}
+//------------------------------------------------------------------
+
+TVerdict CTestRemoteHangup::doTestStepL()
+/**	 Tests line status function
+ * @test GT83-TVOICE-XXX.XX "Test remote hangup of connected call"
+*/
+	{
+	INFO_PRINTF1(_L("Test Remote Hangup"));
+
+	RCall::TStatus lineStatus;
+	TName callName;
+	TBuf<16> goodNumber ;
+	GetGoodNumber(goodNumber) ;
+
+	// Open a Voice Line and Call
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("GT83-TVOICE-XXX.XX"));
+
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, callName), KErrNone, _L("GT83-TVOICE-XXX.XX"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &callName);
+
+	INFO_PRINTF2(_L("Dialling %S...."), &goodNumber);
+	iVoiceCall.Dial(iStatus, goodNumber);
+	User::WaitForRequest(iStatus);
+	TESTL(iStatus==KErrNone);
+
+	// Trigger remote hangup
+	RCall::TStatus notifyLineStatus;
+	TRequestStatus notifyStatus;
+	iLine.NotifyStatusChange(notifyStatus, notifyLineStatus);
+	TESTL(HangMeUpDear() == KErrNone);
+	User::WaitForRequest(notifyStatus);
+	TESTL(notifyStatus.Int() == KErrNone);
+	CHECKPOINT(notifyLineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-XXX.XX")) ;
+	TInt ret = iLine.GetStatus(lineStatus);
+	CHECKPOINT(ret, KErrNone, _L("GT83-TVOICE-XXX.XX")) ;
+	CHECKPOINT(lineStatus, RCall::EStatusHangingUp, _L("GT83-TVOICE-XXX.XX")) ;
+
+	// Close the line and call
+	iVoiceCall.Close();
+	iLine.Close();
+
+	return TestStepResult();
+	}
+
+
+CTestCallDuration::CTestCallDuration()
+	{
+
+	SetTestStepName(_L("TestCallDuration"));
+	}
+
+CTestCallDuration::~CTestCallDuration()
+	{
+
+	}
+
+TVerdict CTestCallDuration::doTestStepL()
+	{
+	TVerdict   Ret,Ret1;
+	INFO_PRINTF1(_L("Call Duration Test"));
+	
+	Ret = RunTestL(FALSE);
+	Ret1 = RunTestL(TRUE);	
+	if(Ret1 == EPass && Ret == EPass)	
+		Ret = EPass;
+	else
+		Ret = EFail;
+	return Ret;
+	}
+
+TVerdict CTestCallDuration::RunTestL(TBool aBRingOut)
+	{
+	//RPhone::TLineInfo lineInfo;
+	TRequestStatus   statDuration;
+	TTimeIntervalSeconds CallLengthDuration,CallLength;
+	TName CallName ;
+
+	CleanupClosePushL(iLine);
+	CleanupClosePushL(iVoiceCall);
+
+	INFO_PRINTF1(_L("Opening Voice Line"));
+	CHECKPOINT(iLine.Open(iPhone,KVoiceLineName), KErrNone, _L("Call Duration Test 1"));
+	INFO_PRINTF1(_L("Opening New Voice Call"));
+	CHECKPOINT(iVoiceCall.OpenNewCall(iLine, CallName), KErrNone, _L("Call Duration Test 2"));
+	INFO_PRINTF2(_L("Voice Call name is %S"), &CallName);
+
+//Test Call Duration 
+	// start notification of call duration.
+	INFO_PRINTF1(_L("Testing Call Duration"));
+	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
+	RingOrDialL(aBRingOut);
+
+	User::WaitForRequest(statDuration);
+	CHECKPOINT(CallLengthDuration.Int() == 1,TRUE,_L(""));
+	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLengthDuration.Int());
+	User::After(5200000);
+	iVoiceCall.GetCallDuration(CallLength);
+	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLength.Int());
+	CHECKPOINT(CallLength.Int() >= 5 ,TRUE,_L("Call Duration Test 3"));
+	
+	// Hang up the Call
+	INFO_PRINTF1(_L("Hanging up the call"));
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	INFO_PRINTF1(_L("HangUp successful"));
+	
+	iVoiceCall.GetCallDuration(CallLength);
+	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLength.Int());
+	
+	TInt numberOfNotifs=0 ;
+	for (; statDuration==KErrNone ;numberOfNotifs++)
+	{
+	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
+	WaitWithTimeout(statDuration,5*KOneSecond);
+	}
+	
+	User::After(6000000);
+//Test Call Duration notification
+
+	INFO_PRINTF1(_L("Testing Call Duration Notification"));
+	RingOrDialL(aBRingOut);
+	User::After(2500000);
+	iVoiceCall.GetCallDuration(CallLength);
+	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLength.Int());
+	CHECKPOINT(CallLength.Int() == 2,TRUE,_L("Call Duration Test 4"));
+
+	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
+	User::WaitForRequest(statDuration);
+	INFO_PRINTF2(TRefByValue<const TDesC>(_L("Call duration = %d")), CallLengthDuration.Int());
+
+	CHECKPOINT(CallLengthDuration.Int() >= 2,TRUE,_L("Call Duration Test 5"));
+	
+	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
+	iVoiceCall.NotifyCallDurationChangeCancel();
+	WaitWithTimeout(statDuration,10*KOneSecond);
+	CHECKPOINT((statDuration.Int()==KErrNone)||(statDuration.Int()==KErrCancel), TRUE, _L("Call Duration Test 6"));
+
+	INFO_PRINTF1(_L("Hanging up the call"));
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	INFO_PRINTF1(_L("HangUp successful"));
+
+//
+	User::After(6000000);
+	
+//Test NotifyCallDurationChangeCancel
+	INFO_PRINTF1(_L("Testing Call Duration Notification Cancel"));
+	iVoiceCall.NotifyCallDurationChange(statDuration,CallLengthDuration);
+	RingOrDialL(aBRingOut);
+	iVoiceCall.NotifyCallDurationChangeCancel();
+	WaitWithTimeout(statDuration,10*KOneSecond);
+	CHECKPOINT(iStatus.Int(), KErrNone, _L("Call Duration Test 7"));
+	
+	User::WaitForRequest(statDuration);
+	// Hang up the Call
+	INFO_PRINTF1(_L("Hanging up the call"));
+	iVoiceCall.HangUp(iStatus);
+	User::WaitForRequest(iStatus);
+	INFO_PRINTF1(_L("HangUp successful"));
+//
+
+	// Close the line and call
+	CleanupStack::PopAndDestroy(&iVoiceCall);
+	CleanupStack::PopAndDestroy(&iLine);
+
+	return TestStepResult();
+
+	}
+
+TBool CTestCallDuration::RingOrDialL(TBool aBRingOut)
+	{
+	if(!aBRingOut)
+		{
+		INFO_PRINTF1(_L("Please ring the phone"));
+		TESTL(CallMeDear() == KErrNone)  ; //init sim incoming call
+		iVoiceCall.AnswerIncomingCall(iStatus);		// wait for a call
+		WaitWithTimeout(iStatus,15*KOneSecond);		// but timeout after 60 seconds
+		CHECKPOINT(iStatus.Int(), KErrNone, _L("Call Duration Test 8"));
+		}
+	else
+		{
+		INFO_PRINTF2(_L("Dialling %S"),&KGoodNumber);
+		iVoiceCall.Dial(iStatus,KGoodNumber);
+		User::WaitForRequest(iStatus);
+		// Wait for the Call Status Change notification
+		TESTL(iStatus==KErrNone);
+		INFO_PRINTF1(_L("...Call is Connected"));
+		}
+	return TRUE;
+	}