sysstatemgmt/systemstarter/test/tsysstart2/src/tsysstart2_procmon.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 00:53:00 +0200
changeset 0 4e1aa6a622a0
permissions -rw-r--r--
Revision: 201003

// 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:
//


#include <e32std.h>
#include "tsysstart2_procmon.h"
#include "testprocgood.h"
#include "testapps.h"


CAppFwkSysStart2TestStepProcMon::CAppFwkSysStart2TestStepProcMon()
	{
	SetTestStepName(KCTestCaseProcMon);
	}



/**
Old Test CaseID 		APPFWK-SYSSTART-0081
New Test CaseID 		DEVSRVS-SYSSTART-STARTUP2-0081
 */

TVerdict CAppFwkSysStart2TestStepProcMon::doTestStepL()
	{	
	
	// The test process should have been started, as indicated in tsysstart2-procmon_emulator.rss
	TFullName name;
	RProcess process;
	CleanupClosePushL( process );

	
	if( ProcessExists(KTestProcGood, name) && (KErrNone == process.Open(name)) )
		{
		INFO_PRINTF1( _L("The test-process was started successfully (as a server) at startup") );		
		INFO_PRINTF1( _L("Now Kill() the test-process and wait for the throttle time") );
		
		
		process.Kill( KSysStart2TestKillCode );
		process.Close();
		User::After( KThrottleTime );
		
		
		if( ProcessExists(KTestProcGood, name) )
			{
			INFO_PRINTF1( _L("The test-process has correctly been restarted") );
			
			// Tell the test-server process to cancel monitoring Then dispose of it
			// and establish that it has not been re-started. 
			LogonAndCancelMonL();
			INFO_PRINTF1( _L("Monitoring of the test-process has been cancelled") );
			
			process.Open( name );
			process.Kill( KSysStart2TestKillCode );
			User::After( KThrottleTime );

			if( !ProcessExists(KTestProcGood, name) )
				{
				INFO_PRINTF1( _L("The test-process has been killed and correctly _not restarted") );
				SetTestStepResult( EPass );	
				}
			else
				{
				ERR_PRINTF1( _L("The test-process has been killed and _incorrectly restarted") );
				SetTestStepResult( EFail );	
				}
						
			}
		
		}
	else
		{
		INFO_PRINTF1(_L("The test-process was not started or a handle could not be opened on it"));	
		
		SetTestStepResult( EFail );
		}

	CleanupStack::PopAndDestroy( &process );
	
	return TestStepResult();	
	}