sysstatemgmt/systemstatemgr/test/testapps/src/ssmcletestproc.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 15 Jul 2010 20:05:35 +0300
branchRCL_3
changeset 55 94cb00198351
parent 0 4e1aa6a622a0
permissions -rw-r--r--
Revision: 201025 Kit: 2010127

// 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:
// usage: ssmtestprocwritetime.exe <output filename> [<timeout (seconds)> [<succeed on run number>]]    *
// 
//

/**
 @file
 @test
 @internalComponent - Internal Symbian test code
*/

#include <e32base.h>
#include <f32file.h>
#include <s32file.h>
#include "ssmcletestapp.h"
#include "ssmtestapps.h"
#include "ssmdebug.h"


static void RunL()
	{
	TSsmCleTestAppArgs args;
	XSsmCleTestApp::GetCommandLineArgsL(args);
	RFs fs;
	User::LeaveIfError(fs.Connect());
	CleanupClosePushL(fs);

	
	TInt count = XSsmCleTestApp::GetRunCountL(fs, args.iLogPrefix);
	if (0 == count)
		{
		XSsmCleTestApp::WriteStartTimeL(fs, args.iLogPrefix);
						
		}
	TInt newCount = XSsmCleTestApp::IncrementRunCountL(fs, args.iLogPrefix);
		

	if ((args.iSucceedOnRun == 0)  && (args.iWaitTime > 0))
		{
		User::After(args.iWaitTime * 1000); 
						
		}
	
	if ((args.iSucceedOnRun != 0) && (args.iSucceedOnRun > count) && (args.iWaitTime > 0))
		{
		User::After(args.iWaitTime * 1000); 
		}

	XSsmCleTestApp::WriteResultL(fs, args.iLogPrefix,args.iFailHow);

	switch (args.iFailHow) //Other failure modes don't require special action
		{
		case EDontFail:
			{
			if ((args.iSucceedOnRun == 0) || ((args.iSucceedOnRun > 0) && (count >= args.iSucceedOnRun)))
				{
				RProcess::Rendezvous(KErrNone);
				}
			else
				{
				RProcess::Rendezvous(KErrBadRendezvousTest);
				}
			break;
			}
		case EPanic:
			{
			User::Panic(_L("SSMTEST"), KSsmCleTestPanic);
			break;
			}
		case EBadRendezvous:
			{
			TBuf<KTestCommandLineMaxLength> prefix = KTestAppLogFileLoc();
			XSsmCleTestApp::WriteResultL(fs, prefix, args.iFailHow);
			RProcess::Rendezvous(KErrBadRendezvousTest);
			break;
			}
		case ENoRendezvous:
		case EMultipleTimeout:
			{
			User::After(10000000); // 10 seconds
			break;
			}
		}
	//Signalling the start of the application
	RSemaphore sem;
	TInt err = sem.OpenGlobal(KStartProcSignalSemaphore);
	RDebug::Print(_L("KStartProcSignalSemaphore Opened with %d"), err);
		
	if(err == KErrNone)
		{
		sem.Signal();
		sem.Close();
		}
	CleanupStack::PopAndDestroy(&fs);
	}

TInt E32Main()
	{
	__UHEAP_MARK;
	CTrapCleanup* cleanup=CTrapCleanup::New();
	TInt r=KErrNoMemory;
	if (cleanup)
		{
		TRAP(r,RunL());
		delete cleanup;
		}

	__UHEAP_MARKEND;

	//This process will return to the user and thus be terminated without cleaning up properly
	//To avoid this we give a wait for request so that we can explicitly clean it up
	TRequestStatus status = KRequestPending;
	User::WaitForRequest(status);
	return r;
	}