traceservices/tracefw/integ_test/ost/TEF/te_ostv2integsuite_functional/src/te_tracecollectorserial.cpp
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:39:58 +0100
branchRCL_3
changeset 24 cc28652e0254
parent 23 26645d81f48d
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201035 Kit: 201035

// 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:
// Example CTestStep derived implementation
//



/**
 @file te_tracecollectorserial.cpp
 @internalTechnology
*/
#include "te_tracecollectorserial.h"
#include "te_ostv2integsuite_defs.h"

using namespace Ulogger; //CA:added so can use old ulogger api
CTCMSerialPluginWrapper::~CTCMSerialPluginWrapper()
/**
 * Destructor
 */
	{
	}

CTCMSerialPluginWrapper::CTCMSerialPluginWrapper()
/**
 * Constructor
 */
	{
	}

CTCMSerialPluginWrapper* CTCMSerialPluginWrapper::NewLC()
	{
	CTCMSerialPluginWrapper* self = new (ELeave)CTCMSerialPluginWrapper();
	CleanupStack::PushL(self);
	self->ConstructL();
	return self;
	}

CTCMSerialPluginWrapper* CTCMSerialPluginWrapper::NewL()
	{
	CTCMSerialPluginWrapper* self=CTCMSerialPluginWrapper::NewLC();
	CleanupStack::Pop(); // self;
	return self;
	}

void CTCMSerialPluginWrapper::ConstructL()
	{
	}

TAny* CTCMSerialPluginWrapper::GetObject()
	{
	return NULL;
	}

TBool CTCMSerialPluginWrapper::DoCommandL(	const TTEFFunction& /*aCommand*/,
					const TTEFSectionName& /*aSection*/, 
					const TInt /*aAsyncErrorIndex*/)
	{
	    if (BlockResult()==EPass)
		{		
		//  ************** Delete the Block, the block start ****************
		
			TInt Result=0;
			SetBlockResult(EPass);
			INFO_PRINTF1(_L("About to test serial plugin"));  //Block start
			RULogger logger;
			Result = logger.Connect();
			INFO_PRINTF2(_L("Connection to Ulogger: %d, attempt: 1"), Result);
                if (Result!=KErrNone)
                {
                INFO_PRINTF1(_L("Connection to Ulogger failed. Will try to connect max. 10 times"));
                for (TInt i=2; i<12;i++)
                   {
                   User::After(1000);
                   Result = logger.Connect();
                   INFO_PRINTF3(_L("Connection to Ulogger: %d, attempt: %d"), Result, i);
                   if (Result==KErrNone)
                        {
                        break;
                        }
                   }
                }
			CClearConfig configIni;
			configIni.Clear(logger);
			CArrayFixFlat<TUint8> *setprimfilter = new (ELeave)CArrayFixFlat<TUint8>(1);
			setprimfilter->AppendL(KGroupId);
			RArray<TUint32> setsecondfilter;
			setsecondfilter.Append((TUint32) KComponentId);
			logger.SetPrimaryFiltersEnabled(*setprimfilter,ETrue);//C.A. previously:logger.EnableClassifications(*setprimfilter);
			logger.SetSecondaryFiltersEnabled(setsecondfilter,ETrue);//C.A. previously:logger.EnableModuleUids(setsecondfilter);
			_LIT8(KTextmedia,"uloggerserialplugin");
			const TPtrC8 mediaptr(KTextmedia);
			// test the plugin can be activated
			Result=logger.ActivateOutputPlugin(mediaptr);//C.A. previously:Result=logger.SetActiveOutputPlugin(mediaptr);	
			if(Result==0||Result==-11)	
			{	
				INFO_PRINTF1(_L("Serial Plugin active"));		
				_LIT(KTextsetting, "output_port");	
				_LIT(KTextvalue, "3");
				// test setting the plugin settings
				TPluginConfiguration pluginConfig;
				pluginConfig.SetKey(KTextsetting);
				pluginConfig.SetValue(KTextvalue);			
				Result=logger.SetPluginConfigurations(mediaptr,pluginConfig);
				if(Result==KErrNone)	
				{
					INFO_PRINTF1(_L("Setting Serial Plugin Settings returns KErrNone but verify set correctly in next step"));
				// test that the plugging settings can be retrieved
				RPointerArray<TPluginConfiguration> getPluginConfigs;
				if(Result==KErrNone)	
				{
					INFO_PRINTF1(_L("Getting Serial Plugin Settings returns KErrNone but verify got correctly in next step"));
					Result=logger.GetPluginConfigurations(mediaptr, getPluginConfigs);
					_LIT(KTextChecksetting, "output_port");
					_LIT(KTextCheckValue, "3");
					// test that the plugging settings retrieved are correct
					if(getPluginConfigs.Count()>0)
						{
						if (!getPluginConfigs[0]->Key().Compare(KTextChecksetting) && !getPluginConfigs[0]->Value().Compare(KTextCheckValue))
							{
							INFO_PRINTF1(_L("Retrieved serial plugin settings are correct"));
							}
							else
								{		
								INFO_PRINTF1(_L("Retrieved serial plugin settings are incorrect"));
								SetBlockResult(EFail);
								}
							Result=logger.Start();//C.A. previously:Result=logger.StartOutputting();
							INFO_PRINTF2(_L("ulogger start returns error %d"), Result);
							TBool OstStatus=0;
#ifndef __WINSCW__	
#ifdef TE_UPT_TRACE_ENABLED
OstStatus = 1;
INFO_PRINTF1(_L("TRACING HAS BEEN ENABLED!"));
#else
OstStatus = 0;
INFO_PRINTF1(_L("TRACING HAS BEEN DISABLED! All Log files should be empty/not exist"));
#endif // trace enabled
							TTraceContext attrs(KComponentId, KGroupId, KContextId, KPc);						
							if(!OstTrace(attrs, KInitialClientFormat, KAny16)&&OstStatus)
								{
								INFO_PRINTF1(_L("Ost first trace via serial plugin failed"));
								SetBlockResult(EFail);
								}
							TTraceContext attrs1(KComponentId, KGroupId, KContextId, KPc);
							if(!OstTrace(attrs1, KInitialClientFormat, KAny16)&&OstStatus)
								{
								INFO_PRINTF1(_L("Ost second trace writing via serial plugin failed"));
								SetBlockResult(EFail);
								}
#endif	//winscw			
							logger.Stop();//C.A. previously:logger.StopOutputting();	
						}
					else
						{		
						INFO_PRINTF1(_L("Either SetPluginConfiguration failed or GetPluginConfiguration failed as returned a zero size array"));
						SetBlockResult(EFail);
						}
				}
				else
				{
					INFO_PRINTF1(_L("Failed to get serial Plugin Settings"));
					SetBlockResult(EFail);
				}
				getPluginConfigs.ResetAndDestroy();
			}
			else
			{
				INFO_PRINTF1(_L("Serial Plugin Settings error"));
				SetBlockResult(EFail);
			}					
		}
		else
		{			
			INFO_PRINTF1(_L("Serial Plugin error when activated"));
			SetBlockResult(EFail);
		}		
		TBuf8<32>activeplugins;	
		_LIT8(KTextmedia1,"uloggerserialplugin");
		TBuf8<32> checkplugins(KTextmedia1);
		// test the active plugin name can be retrieved
		logger.GetActiveOutputPlugin(activeplugins);//C.A. previously:logger.ActiveOutputPlugin(activeplugins);
		if (activeplugins.Compare(checkplugins)==0)
			INFO_PRINTF1(_L("Got correct active serial plugin"));
		else
		{
			INFO_PRINTF1(_L("Got incorrect active serial plugin"));
			SetBlockResult(EFail);
		}
		// test activating the second plugin
		_LIT8(KTextmedia2,"te_fileplugin");
		const TPtrC8 mediaptr2(KTextmedia2);
		Result=logger.ActivateOutputPlugin(mediaptr2);	//C.A. previously:Result=logger.SetActiveOutputPlugin(mediaptr2);	
		if(Result==0)			
			INFO_PRINTF1(_L("Second plugin activated correctly"));
		else
		{
			INFO_PRINTF1(_L("Second plugin activation error"));
			SetBlockResult(EFail);
		}
		// test the first plugin can now be removed as it is no longer the active plugin
		Result=logger.RemovePluginConfigurations(mediaptr);
		if(Result==0)
		{	
			INFO_PRINTF1(_L("Removed serial Plugin correctly"));
		}
		else
		{
			INFO_PRINTF1(_L("Failed to remove serial Plugin"));
			SetBlockResult(EFail);
		}
		logger.Stop();//C.A. previously:logger.StopOutputting();
		logger.Close();
		INFO_PRINTF1(_L("serial plugin tests complete!"));
		
		//  **************   Block end ****************
		}
		
	  	return ETrue;
	}