appfw/apparchitecture/tef/T_ControlPanelTest.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 15 Mar 2010 12:41:10 +0200
branchRCL_3
changeset 13 096dad6e50a9
parent 0 2e3d3ce01487
child 29 6a787171e1de
permissions -rw-r--r--
Revision: 201009 Kit: 201010

// Copyright (c) 2007-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:
// Tests control panel Application Apparc base classes and utility functions to get application's data.\n
// 
// t_controlpaneltest.cpp
//

/**
 @file t_controlpaneltest.cpp
 @internalComponent - Internal Symbian test code 
*/

#include <f32file.h>
#include <fbs.h>
#include <s32std.h> 
#include <s32stor.h> 
#include <s32file.h> 

#include <apaid.h>
#include "../apparc/apadll.h"
#include <apgaplst.h>
#include <apgicnfl.h>
#include <apgdoor.h>
#include <apfrec.h>
#include <apfctlf.h>
#include <apgctl.h>
#include <apgaplst.h>
#include <apaflrec.h>
#include <apgcli.h>
#include <apacmdln.h>
#include "appfwk_test_appui.h"

#include "T_ControlPanelTest.h"
#include "tstapp.h"
#include <w32std.h>

#if !defined(__E32TEST_H__)
#include <e32test.h>
#endif

_LIT(KCompleted, "Completed.");


_LIT(KRSCDIR,"C:\\Resource\\apps\\");
_LIT(KRSCREGDIR,"C:\\private\\10003a3f\\import\\apps\\");
_LIT(KNEWCTLPATH,"C:\\sys\\bin\\app_CTRL2.exe");
_LIT(KSRCRESOURCEPATH,"Z:\\private\\10003a3f\\import\\apps\\App_CTRL2_reg.Rsc");
_LIT(KDESTRESOURCEPATH,"C:\\private\\10003a3f\\import\\apps\\App_CTRL2_reg.Rsc");

LOCAL_D TInt SimulateKeyL(TAny*)
	{
	User::After(3000000);
	RWsSession session;
	User::LeaveIfError(session.Connect());	
	//control down
	TRawEvent rawEvent;

	rawEvent.Set(TRawEvent::EKeyDown,EStdKeyLeftCtrl);
	session.SimulateRawEvent(rawEvent);

	// e down
	rawEvent.Set(TRawEvent::EKeyDown,'E');
	session.SimulateRawEvent(rawEvent);

	// e up
	rawEvent.Set(TRawEvent::EKeyUp,'E');
	session.SimulateRawEvent(rawEvent);

	//control up
	rawEvent.Set(TRawEvent::EKeyUp,EStdKeyLeftCtrl);
	session.SimulateRawEvent(rawEvent);

	session.Flush();
	
	session.Close();
	return KErrNone;
	}

void CT_ControlPanelTestStep::RemoveFilesFromCDrive()
	{
	TInt ret = iTestServ.SetReadOnly(KDESTRESOURCEPATH,0); //remove READ ONLY option
	TEST(ret==KErrNone);

	TRAP(ret,iTestServ.DeleteFileL(KDESTRESOURCEPATH));
	TEST(ret==KErrNone);
	}



/**
  Auxiliary Fn for Test Case ID T-ControlPanelStep-testControls1L,
  T-ControlPanelStep-testControls2L, T-ControlPanelStep-testControls3L
 
  The method finds the index of control app_ctrl2.exe in the control list.
  Depending on the Boolean value of argument aIsNewPath the search is
  done on ROM / RAM.\n
 
*/

TInt CT_ControlPanelTestStep::ControlIndexInList(CApaSystemControlList* aList, TBool aIsNewPath)
	{
	TFileName ctlPath=_L("Z:\\sys\\bin\\app_CTRL2.exe");
	TFileName newCtlPath=_L("c:\\sys\\bin\\app_ctrl2.exe");
	const TInt count = aList->Count();
	TInt retVal = KErrNotFound;
	for(TInt ii = 0; ii < count; ++ii)
		{		
		if(((aList->Control(ii)->FileName().CompareF(ctlPath)==0) && (!aIsNewPath)) ||
			((aList->Control(ii)->FileName().CompareF(newCtlPath)==0) && (aIsNewPath)))
			{
			retVal = ii;
			
			
			if(aList->Control(ii)->FileName().CompareF(ctlPath)==0)
				{
				INFO_PRINTF1(_L("***Found control on the z: drive"));
				}
			else
				{
				INFO_PRINTF1(_L("***Found control on the c: drive"));
				}
			break;
			}
		}
	INFO_PRINTF2(_L("Out [%d] controlIndexInList"),retVal);	
	return retVal;
	}


/**
   @SYMTestCaseID T-ControlPanelStep-testControls1L
  
   @SYMPREQ
  
   @SYMTestCaseDesc Tests CApaSystemControlList::UpdateL().
   
   @SYMTestPriority High 
  
   @SYMTestStatus Implemented
   
   @SYMTestActions Check the control list to find the number of controls in the
   list and the number of updates to the list. Call UpdateL(). Check the list
   again for no change in the count of controls and updates to the list.\n
   API Calls:\n	
   CApaSystemControlList::UpdateL()\n
   
   @SYMTestExpectedResults Test confirms that there is no change in the control
   list after updating.
 */
void CT_ControlPanelTestStep::testControls1L()
	{
	INFO_PRINTF1(_L("In testControls1L......"));
	
	iControlCount1 = iControlList->Count();
	TEST((iControlCount1>=1));
	
	TEST((iControlList->UpdateCount()>=1));//update count returns 1 if new list
	//
	// do an update - there should be no changes
	TInt ret;
	INFO_PRINTF1(_L("Updating the list ......"));
	TRAP(ret, iControlList->UpdateL());
	TEST(ret==KErrNone);
	iControlCount2 = iControlList->Count();
	TEST(iControlCount2 == iControlCount1);	
	TEST((iControlList->UpdateCount()>=1));
	iIndex = ControlIndexInList(iControlList,EFalse);
	TEST((iIndex >= 0) && (iIndex < iControlCount2));
	
	INFO_PRINTF1(_L("Out testControls1L......"));
	}


/**
   @SYMTestCaseID T-ControlPanelStep-testControls2L
  
   @SYMPREQ
  
   @SYMTestCaseDesc Tests CApaSystemControlList::UpdateL() and UpdateCount().
   
   @SYMTestPriority High 
  
   @SYMTestStatus Implemented
   
   @SYMTestActions Copy control from Z: drive to C: drive. Call UpdateL() to
   update the control list. Check if UpdateL() has incremented iUpdateCount
   by calling UpdateCount(). Check the filename of control to ensure that the
   control copied to C: drive has been updated in the list. Delete the newly
   copied control.\n
   API Calls:\n	
   CApaSystemControlList::UpdateL()\n
   CApaSystemControlList::UpdateCount()const\n
   
   @SYMTestExpectedResults The test shows updating of the copied control in control list.
 */

void CT_ControlPanelTestStep::testControls2L()
	{
	INFO_PRINTF1(_L("In testControls2L......"));	
	
	iTestServ.CreateDirectoryL(KRSCDIR);
	iTestServ.CreateDirectoryL(KRSCREGDIR);

	TInt ret=iTestServ.CopyFileL(KSRCRESOURCEPATH,KDESTRESOURCEPATH);
	TEST(ret==KErrNone);
	
	INFO_PRINTF1(_L("Files Copied to C Drive......"));
	INFO_PRINTF1(_L("Updating the list ......"));
	iControlCount=iControlList->UpdateCount();
	while(iControlList->UpdateCount()<=iControlCount)
		{
		TRAP(ret, iControlList->UpdateL());
		if(ret!=KErrNone)
			{
			break;				
			}
		User::After(100000);	
		}

	INFO_PRINTF2(_L("In testControls2L After Controllist update [%d]......"),ret);
	TEST(ret==KErrNone);
	iControlCount3 = iControlList->Count();
	TEST(iControlCount3 == iControlCount1);
	TEST((iControlList->UpdateCount()>=2));
	iIndex = ControlIndexInList(iControlList,ETrue);
	TEST((iIndex >= 0) && (iIndex < iControlCount3));

	TFileName name=iControlList->Control(iIndex)->FileName();
	TEST(name.CompareF(KNEWCTLPATH)==0);
	RemoveFilesFromCDrive();
	INFO_PRINTF1(_L("Removed the file from C Drive......"));
	INFO_PRINTF1(_L("Updating the list ......"));
	iControlCount=iControlList->UpdateCount();
	while(iControlList->UpdateCount()<=iControlCount)
		{
		TRAPD(ret, iControlList->UpdateL());
		if(ret!=KErrNone)
			{
			break;				
			}
		User::After(100000);
		}
	INFO_PRINTF1(_L("Out testControls2L......"));
	}

/**
   @SYMTestCaseID T-ControlPanelStep-testControls3L
  
   @SYMPREQ
  
   @SYMTestCaseDesc Tests CApaSystemControlList::Control() and CApaSystemControl APIs Type() and Caption().
   
   @SYMTestPriority High 
  
   @SYMTestStatus Implemented
   
   @SYMTestActions Update the control list to ensure that the deleted control is
   removed from the list and the control on the Z: Drive is added to the list.
   Retrieve this control from the list using CApaSystemControlList::Control(). 
   Check the type and caption of the control calling Type() and Caption() methods.\n
   API Calls:\n	
   CApaSystemControlList::Control(TInt aIndex)const\n
   CApaSystemControl::Type()const\n
   CApaSystemControl::Caption()const\n
   
   @SYMTestExpectedResults The test shows the addition of the control present on 
   Z: drive in control list. Test confirms the retrieved info on the control
   obtained from the control list.
  
 */
void CT_ControlPanelTestStep::testControls3L()
	{
	INFO_PRINTF1(_L("In testControls3L......"));
	TFileName ctlPath=_L("Z:\\sys\\bin\\app_ctrl2.exe");
	TFileName ctlCaption=_L("app_ctrl2");
	// This method is called to close the panic dialog generated by previous test
	CloseAllPanicWindowsL();
	
	INFO_PRINTF1(_L("IN testControls3L Before Updating the list......"));
	TRAPD(ret, iControlList->UpdateL());
	
	TEST(ret==KErrNone);
	const TInt controlCount4 = iControlList->Count();
	TEST(controlCount4 == iControlCount1);	// no changes in the count
	TEST((iControlList->UpdateCount()>=3));

	iIndex = ControlIndexInList(iControlList,EFalse);
	TEST((iIndex >= 0) && (iIndex < controlCount4));
	TEST(iControlList->Control(iIndex)->FileName().CompareF(ctlPath)==0);
	
	INFO_PRINTF1(_L("Testing CApaSystemControl"));
	//
	//get the control from the list and check it's type and caption
	iControl=iControlList->Control(iIndex);
	TEST(iControl!=NULL);
	TFileName caption=iControl->Caption();
	TEST(caption.CompareF(ctlCaption)==0);
	TEST(iControl->Icon()!=NULL);
	
	RThread thread;
	TFullName name=_L("Control Panel Test");
	TInt r=thread.Create(name,SimulateKeyL,KDefaultStackSize,KDefaultStackSize,KDefaultStackSize,NULL);
	TEST(r==KErrNone);
	thread.Resume();
		
	// run the control
	TRAP(ret, iControl->CreateL()); // this call is synchronous
	TEST(ret==KErrNone);
	
	thread.Close();
	INFO_PRINTF1(_L("Out testControls3L......"));
	}

/**
   Auxiliary Fn for T-ControlPanelStep-testControls1L, T-ControlPanelStep-testControls2L, T-ControlPanelStep-testControls3L
   
   This method creates a control list by calling CApaSystemControlList::NewL() and 
   initiates subsequent tests on CApaSystemControlList and CApaSystemControl APIs.
    
 */
void CT_ControlPanelTestStep::testControlsL()
	{
	INFO_PRINTF1(_L("Testing CApaSystemControlList"));
	
	//Create a session with F & B server
	TInt ret=RFbsSession::Connect();
	TEST(!ret);

	TRAP(ret,iControlList=CApaSystemControlList::NewL(iFs));
	TEST(ret==KErrNone);

	TRAPD(err,testControls1L());
	TRAP(err,testControls2L());
	TRAP(err,testControls3L());

	delete iControlList;

	//Close the session F & B server.
	RFbsSession::Disconnect();
	}


/**
  Auxiliary Fn for all Test Cases.
 
  This method creates and installs an active scheduler and puts the
  test code on the scheduler as a CIdle object. The method initiates
  all tests by calling the static method CT_ControlPanelTestCallBack::CallBack().
 
*/
void CT_ControlPanelTestStep::DoStepTestsInCallbackL()
	{
	// create an active scheduler
	CActiveScheduler* scheduler = new(ELeave) CActiveScheduler;
	CActiveScheduler::Install(scheduler);
	CleanupStack::PushL(scheduler);

	// put the test code onto the scheduler as an idle object
	CIdle* idle=CIdle::NewL(-20);
	CleanupStack::PushL(idle);

	CT_ControlPanelTestCallBack* callBack = new(ELeave) CT_ControlPanelTestCallBack(this);
	CleanupStack::PushL(callBack);

	idle->Start(TCallBack(CT_ControlPanelTestCallBack::CallBack,callBack));
	// start the test code
	CActiveScheduler::Start();

	// all outstanding requests complete - kill the scheduler
	CleanupStack::PopAndDestroy(3); //scheduler, callBack, idle
	}


/**
  Auxiliary Fn for all Test Cases.
 
  The method initiates all tests to be performed.
 
*/
void CT_ControlPanelTestStep::DoStepTests()
	{
	__UHEAP_MARK;
	INFO_PRINTF1(_L("Test Controls......"));
	TRAPD(r,testControlsL());
	TEST(r==KErrNone);
	INFO_PRINTF1(KCompleted);
	__UHEAP_MARKEND;
	}


CT_ControlPanelTestStep::~CT_ControlPanelTestStep()
/**
   Destructor
 */
	{
	}

CT_ControlPanelTestStep::CT_ControlPanelTestStep()
/**
   Constructor
 */
	{
	// Call base class method to set up the human readable name for logging
	SetTestStepName(KT_ControlPanelTest);
	}

TVerdict CT_ControlPanelTestStep::doTestStepPreambleL()
/**
   @return - TVerdict code
   Override of base class virtual
 */
	{
	SetTestStepResult(EPass);
	return TestStepResult();
	}

TVerdict CT_ControlPanelTestStep::doTestStepPostambleL()
/**
   @return - TVerdict code
   Override of base class virtual
 */
	{
	return TestStepResult();
	}


TVerdict CT_ControlPanelTestStep::doTestStepL()
/**
  @return - TVerdict code
  Override of base class virtual
*/
	{
	INFO_PRINTF1(_L("Testing Apparc ...T_ControlPanel"));

	// set up the directory structure
	User::LeaveIfError(iFs.Connect());
	
	// connect to the test utils server
	User::LeaveIfError(iTestServ.Connect());
	
	// Run the tests...w	
	TRAPD(ret,DoStepTestsInCallbackL())
	TEST(ret==KErrNone);

	// Close everything
	iFs.Close();
	iTestServ.Close();

	INFO_PRINTF1(_L("T_ControlPanel Completed."));
	return TestStepResult();
	}


TInt CT_ControlPanelTestCallBack::CallBack(TAny* callBack /*aThis*/)
/**
  This static method is the callback function of CIdle object. The method
  calls the non-static method DoStepTests() which initiates all the tests. 
*/
	{
	
	//Call Test Step func

	((CT_ControlPanelTestCallBack *)callBack)->iTestStep->DoStepTests();
	
	CActiveScheduler::Stop();
	return EFalse; // don't call back again
	}


CT_ControlPanelTestCallBack::CT_ControlPanelTestCallBack(CT_ControlPanelTestStep* aTestStep)
/**
   Constructor
 */
	{
	iTestStep = aTestStep;
	}

CT_ControlPanelTestCallBack::~CT_ControlPanelTestCallBack()
/**
   Destructor
 */
	{

	}