kerneltest/e32test/bench/t_proc2.cpp
author John Imhofe
Mon, 19 Oct 2009 15:55:17 +0100
changeset 0 a41df078684a
permissions -rw-r--r--
Convert Kernelhwsrv package from SFL to EPL kernel\eka\compsupp is subject to the ARM EABI LICENSE userlibandfileserver\fatfilenameconversionplugins\unicodeTables is subject to the Unicode license kernel\eka\kernel\zlib is subject to the zlib license

// Copyright (c) 1996-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the License "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:
// e32test\bench\t_proc2.cpp
// The other half of the process relative type test stuff
// 
//
										
#include <e32test.h>
#include "t_proc.h"

RTest test(_L("T_PROC2"));
RTest testSvr(_L("Server"));

void CMySession::DisplayName(const RMessage2& aMessage, const TDesC& aText)
//
// Display the client's name.
//
	{
	RThread client;
	TInt r = aMessage.Client(client);
	test(r == KErrNone);
	TFullName name = client.FullName();
	client.Close();
	testSvr.Printf(_L("Session %S\n%S\n"), &name, &aText);
	}

void CMySession::ServiceL(const RMessage2& aMessage)
//
// Handle messages for this server.
//
	{

	TInt r=KErrNone;
	TBuf<0x100> b;
	switch (aMessage.Function())
		{
	case CMyServer::EDisplay:
		TRAP(r,aMessage.ReadL(0,b));
		DisplayName(aMessage, b);
		break;
	case CMyServer::ERead:
		TRAP(r,aMessage.ReadL(0,b));
		if (r==KErrNone && b!=_L("Testing read"))
			r=KErrGeneral;
		if (r==KErrNone)
			{
			TRAP(r,aMessage.ReadL(0,b,-1));
			if (r==KErrNone)
				r=KErrGeneral;
			if (r==KErrArgument)
				r=KErrNone;
			}
		if (r==KErrNone)
			{
			TInt i = TInt(0xfefefefe);
			TRAP(r,aMessage.ReadL(i,b));
			if (r==KErrNone)
				r=KErrGeneral;
			if (r==KErrBadDescriptor)
				r=KErrNone;
			}
		break;
	case CMyServer::EWrite:
		TRAP(r,aMessage.WriteL(0,_L("It worked!")));
		if (r==KErrNone)
			{
			TRAP(r,aMessage.WriteL(0,b,-1));
			if (r==KErrNone)
				r=KErrGeneral;
			if (r==KErrArgument)
				r=KErrNone;
			}
		if (r==KErrNone)
			{
			TRAP(r,aMessage.WriteL(1,b));
			if (r==KErrNone)
				r=KErrGeneral;
			if (r==KErrBadDescriptor)
				r=KErrNone;
			}
		break;
	case CMyServer::ETest:
		break;
	case CMyServer::EStop:
		CActiveScheduler::Stop();
		break;
	default:
		r=KErrNotSupported;
		}
	aMessage.Complete(r);
	}

CMyServer* CMyServer::New(TInt aPriority)
//
// Create a new CMyServer.
//
	{

	return new CMyServer(aPriority);
	}

CMyServer::CMyServer(TInt aPriority)
//
// Constructor.
//
	: CServer2(aPriority)
	{}

CSession2* CMyServer::NewSessionL(const TVersion& aVersion, const RMessage2&) const
//
// Create a new client for this server.
//
	{

	TVersion v(KMajorVersionNumber,KMinorVersionNumber,KBuildVersionNumber);
	if (!User::QueryVersionSupported(v,aVersion))
		User::Leave(KErrNotSupported);
	return(new(ELeave) CMySession());
	}

void CMyActiveScheduler::Error(TInt anError) const
//
// Called if any Run() method leaves.
//
	{

	testSvr.Panic(anError,_L("CMyActiveScheduler::Error"));
	}

LOCAL_C TInt serverThreadEntryPoint(TAny*)
//
// The entry point for the producer thread.
//
	{

//	testSvr.Title();
//	testSvr.Start(_L("Create CActiveScheduler"));
	CMyActiveScheduler* pR=new CMyActiveScheduler;
//	testSvr(pR!=NULL);
	CActiveScheduler::Install(pR);
//
//	testSvr.Next(_L("Create CMyServer"));
	CMyServer* pS=CMyServer::New(0);
//	testSvr(pS!=NULL);
//
//	testSvr.Next(_L("Start CMyServer"));

	pS->Start(KServerName);

//	TInt r=pS->Start();
//	testSvr(r==KErrNone);
//
//	testSvr.Next(_L("Signal to client that we have started"));
//	client.Signal();
//
//	testSvr.Next(_L("Start CActiveScheduler"));
	CActiveScheduler::Start();
//
//	testSvr.Next(_L("Exit server"));
//	testSvr.Close();

	return(KErrNone);
	}


void init()
	{
	// create server thread
	RThread server;
	TInt r=server.Create(_L("Server"),serverThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,NULL);
	test(r==KErrNone);
	server.SetPriority(EPriorityMore);
	server.Resume();

	r=globSem1.OpenGlobal(_L("GlobSem1"));
	test(r==KErrNone);
	r=globSem2.OpenGlobal(_L("GlobSem2"));
	test(r==KErrNone);
	globSem1.Signal(); // finished init
	}

void sharedChunks()
	{

	globSem2.Wait(); // wait for chunk test to be set up

	RChunk c;
	TInt r=c.OpenGlobal(_L("Marmalade"),EFalse);
	test(r==KErrNone);
    test.Printf(_L("Chunk opened\r\n"));
	TUint8* base=c.Base();
    test.Printf(_L("Chunk address %x\r\n"),base);
	for (TInt8 i=0;i<10;i++)
		test(*base++==i); // check the chunk has 0-9
    test.Printf(_L("Chunk contents tested\r\n"));
  	c.Close();
	globSem1.Signal(); // say we've done it
	}

TInt sharedChunks2(TAny* /*aDummy*/)
	{

    RTest test(_L("Shared Chunks 2"));

	globSem2.Wait(); // wait for chunk test to be set up

	RChunk c;
	TInt r=c.OpenGlobal(_L("Marmalade"),EFalse);
	test(r==KErrNone);
    test.Printf(_L("Chunk opened\r\n"));
	TUint8* base=c.Base();
    test.Printf(_L("Chunk address %x\r\n"),base);
	for (TInt8 i=0;i<10;i++)
		test(*base++==i); // check the chunk has 0-9
    test.Printf(_L("Chunk contents tested\r\n"));
  	c.Close();
	globSem1.Signal(); // say we've done it
    return(KErrNone);
	}

TInt E32Main()
	{	
 
	test.Title();

	test.Start(_L("Testing process stuff 2"));

	test.Next(_L("Check that T_PROC1 is running"));
	TFindProcess fProcess(_L("*T_PROC1*"));
	TFullName n;
	TInt r=fProcess.Next(n);
	if (r!=KErrNone)
		{
		test.Printf(_L("This test should not be run from the command line.\n"));
		test.Printf(_L("Run T_PROC1, which loads this test.\n"));
		test.End();
		test.Close();
		return (KErrNone);
		}

	test.Next(_L("Initialize"));
	init();

	test.Next(_L("Shared chunks from primary thread"));
	sharedChunks();
	
	test.Next(_L("Shared chunks from secondary thread"));
	RThread t;
	r=t.Create(_L("Shared chunks 2"),sharedChunks2,KDefaultStackSize,KHeapSize,KHeapSize,NULL);
    test(r==KErrNone);
	TRequestStatus s;
	t.Logon(s);
	t.Resume();
	User::WaitForRequest(s);
	test(s==KErrNone);
	CLOSE_AND_WAIT(t);

	test.Close();
	globSem1.Signal(); // tell proc1 I'm ready

//	test.Next(_L("Wait for first process to do speed tests"));
	globSem2.Wait();
	
	return(KErrNone);
	}