testexecfw/tef/test/legacy/sampleclient/src/sampleclient.cpp
author Johnson Ma <johnson.ma@nokia.com>
Mon, 08 Mar 2010 15:03:44 +0800
changeset 0 3e07fef1e154
permissions -rw-r--r--
Initial EPL Contribution

/*
* Copyright (c) 2005-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:  
* Demonstration use of the TestExecuteUtils client API
* Relies on test config files being exported to z:\SampleTest
*
*/



/**
 @file SampleClient.cpp
*/
#include <TestExecuteClient.h>

LOCAL_C void MainL()
	{
	// Create a root session with the SampleServer test server
	// User::After() 1/10th second delays between server calls because IPC calls fail with
	// KErrServerBusy if we bang them in to fast.
	RTestServ server;
	User::LeaveIfError(server.Connect(_L("SampleServer")));
	CleanupClosePushL(server);
	
	RTestSession session1;
	User::LeaveIfError(session1.Open(server,_L("SampleStep1")));
	CleanupClosePushL(session1);
	TRequestStatus status1;
	User::After(100000);
	// Run a test step then pick up completion
	TExitCategoryName panicString1;
	session1.RunTestStep(_L("z:\\Sampletest\\SampleTest.ini SectionOne"),panicString1,status1);
	User::WaitForRequest(status1);
	// Demonstration of another step run on the same session
	// We have to wait for the first step to complete otherwise we get KErrInUse
	// If we want to run multiple instances then we create another test session
	panicString1.Zero();
	session1.RunTestStep(_L("z:\\Sampletest\\SampleTest.ini SectionTwo"),panicString1,status1);
	
	// Get another session whilst the other one is still running
	RTestSession session2;
	User::After(100000);
	User::LeaveIfError(session2.Open(server,_L("SampleStep1")));
	CleanupClosePushL(session2);
	TRequestStatus status2;
	User::After(100000);
	TExitCategoryName panicString2;
	session2.RunTestStep(_L("z:\\Sampletest\\SampleTest.ini SectionTwo"),panicString2,status2);
	
	// Get another session whilst the other two are still running
	RTestSession session3;
	User::After(100000);
	User::LeaveIfError(session3.Open(server,_L("SampleStep1")));
	CleanupClosePushL(session3);
	TRequestStatus status3;
	User::After(100000);
	TExitCategoryName panicString3;
	session3.RunTestStep(_L("z:\\Sampletest\\SampleTest.ini SectionTwo"),panicString3,status3);

	// The test steps all ran concurrently so pick up the completions
	User::WaitForRequest(status1);
	User::WaitForRequest(status2);
	User::WaitForRequest(status3);

	session1.Close();
	session2.Close();
	session3.Close();

	CleanupStack::Pop(3);
	CleanupStack::Pop(&server);
	// Close the root server session
	server.Close();
	// Wait for flogger to log
	User::After(5000000);
	}

// Entry point for all Epoc32 executables
// See PSP Chapter 2 Getting Started
GLDEF_C TInt E32Main()
	{
	// Heap balance checking
	// See PSP Chapter 6 Error Handling
	__UHEAP_MARK;
	CTrapCleanup* cleanup = CTrapCleanup::New();
	if(cleanup == NULL)
		{
		return KErrNoMemory;
		}
	TRAPD(err,MainL());
	_LIT(KPanic,"SampleClient");
	__ASSERT_ALWAYS(!err, User::Panic(KPanic,err));
	delete cleanup;
	__UHEAP_MARKEND;
	return KErrNone;
    }