crypto/weakcryptospi/test/tbigint/tbigintmain.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 02 Oct 2009 13:15:59 +0300
changeset 10 afc583cfa176
parent 8 35751d3474b7
child 102 deec7e509f66
permissions -rw-r--r--
Revision: 200938

/*
* Copyright (c) 1998-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: 
*
*/


#include <e32base.h>
#include "t_testhandler.h"
#include "tscripttests.h"
#include "t_testsetup.h"
#include "t_input.h"
#include "t_output.h"
#include "tbigint.h"
#include "tconstructionfb.h"
#include "tconstructionvector.h"
#include "tbasicmathsvector.h"
#include "tbasicmathsfb.h"
#include "tmontgomeryvector.h"
#include "tmontgomeryfb.h"
#include "tprimevector.h"
#include "tmontgomeryperformance.h"
#include "tprimegenperformance.h"
#include "tprimevectorperformance.h"
#include "tprimegen.h"
#include "tprimegenvector.h"
#include <random.h>

LOCAL_D void callExampleL() // initialize and call example code under cleanup stack
    {
    START_SCRIPT_LIST
	SCRIPT_ITEM(CMontgomeryPerformance,_L8("MontgomeryPerformance")),
	SCRIPT_ITEM(CPrimeVector,_L8("PrimeVector")),
	SCRIPT_ITEM(CConstructionFB,_L8("ConstructionFB")),
	SCRIPT_ITEM(CConstructionVector,_L8("ConstructionVector")),
	SCRIPT_ITEM(CBasicMathsVector,_L8("BasicMathsVector")),
	SCRIPT_ITEM(CBasicMathsFB,_L8("BasicMathsFB")),
	SCRIPT_ITEM(CMontgomeryVector,_L8("MontgomeryVector")),
	SCRIPT_ITEM(CMontgomeryFB,_L8("MontgomeryFB")),
	SCRIPT_ITEM(CPrimeGenPerformance,_L8("PrimeGenPerformance")),
	SCRIPT_ITEM(CPrimeVectorPerformance,_L8("PrimeVectorPerformance")),
	SCRIPT_ITEM(CPrimeGen,_L8("PrimeGen")),
	SCRIPT_ITEM(CPrimeGenVector,_L8("PrimeGenVector"))
	END_SCRIPT_LIST

//	Either run the top level build and test script or, if running this test specifically, 
//	uncomment the following and it'll run them all one after the other

    CSystemRandom *rng = CSystemRandom::NewL();
    SetThreadRandomLC(rng);

	TDriveUnit sysDrive (static_cast <TInt> (RFs::GetSystemDrive()));
	TBuf<64> scriptFile = sysDrive.Name();
	scriptFile.Append(_L("\\tbigint\\tbasicmathstests.txt"));
	TBuf<64> logFile = sysDrive.Name();
	logFile.Append(_L("\\tbigint\\tbasicmaths.log"));
	
	CTestSetup::CreateAndRunTestsL(theTestTypes, scriptFile, logFile);
	
/*	CTestSetup::CreateAndRunTestsL(theTestTypes, 
		_L("c:\\tbigint\\tconstructiontests.txt"),
		_L("c:\\tbigint\\tconstruction.log"));
	CTestSetup::CreateAndRunTestsL(theTestTypes, 
		_L("c:\\tbigint\\tprimegen.txt"),
		_L("c:\\tbigint\\tprimegen.log"));
	CTestSetup::CreateAndRunTestsL(theTestTypes, 
		_L("c:\\tbigint\\tprimegenperformance.txt"),
		_L("c:\\tbigint\\tprimegenperformance.log"));
	CTestSetup::CreateAndRunTestsL(theTestTypes, 
		_L("c:\\tbigint\\tmontgomerytests.txt"),
		_L("c:\\tbigint\\tmontgomery.log"));
	CTestSetup::CreateAndRunTestsL(theTestTypes, 
		_L("c:\\tbigint\\tperformancetests.txt"),
		_L("c:\\tbigint\\tperformance.log"));
	CTestSetup::CreateAndRunTestsL(theTestTypes, 
		_L("c:\\tbigint\\tprimetests.txt"),
		_L("c:\\tbigint\\tprime.log"));
	CTestSetup::CreateAndRunTestsL(theTestTypes, 
		_L("c:\\tbigint\\tprimetests2.txt"),
		_L("c:\\tbigint\\tprime2.log"));
*/
	
	DestroyThreadRandom();
	CleanupStack::Pop(); // Pop the cleanup item which would have reset/delete the threadrandom
    }

GLDEF_C TInt E32Main() // main function called by E32
    {
	__UHEAP_MARK;
	CTrapCleanup* cleanup = CTrapCleanup::New(); // get clean-up stack
	TRAPD(error, callExampleL());
	__ASSERT_ALWAYS(!error,User::Panic(_L("bigint"),error));
	delete cleanup; // destroy clean-up stack
	__UHEAP_MARKEND;
	return 0;
    }