persistentstorage/store/TFILE/t_storcorrupt.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 19 Aug 2010 11:36:21 +0300
branchRCL_3
changeset 21 28839de615b4
parent 0 08ec8eefde2f
permissions -rw-r--r--
Revision: 201033 Kit: 201033

// 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 "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 <s32file.h>
#include <e32test.h>

const TInt KTestCleanupStack=0x20;
const TPtrC KTestDir=_L("\\STOR-TST\\T_CORUPT\\");

#ifdef _DEBUG
const TPtrC alphabet(_S("abcdefghijklmnopqrstuvwxyz"),26);
LOCAL_D CFileStore* store;
LOCAL_D CFileStore* storeCopy;
LOCAL_D RFile file;
RStoreWriteStream out;
RStoreReadStream in;
_LIT(KFileName, "t_storcorrupt2.dat");
#endif

LOCAL_D CTrapCleanup* TheTrapCleanup;
LOCAL_D RTest TheTest(_L("t_storcorrupt"));
LOCAL_D RFs TheFs;

///////////////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////////////
//Tests macros and functions.
//If (!aValue) then the test will be panicked, the test data files will be deleted.
static void Check(TInt aValue, TInt aLine)
	{
	if(!aValue)
		{
		TheTest.Printf(_L("*** Boolean expression evaluated to false!\r\n"));
		TheTest(EFalse, aLine);
		}
	}
//If (aValue != aExpected) then the test will be panicked, the test data files will be deleted.
static void Check(TInt aValue, TInt aExpected, TInt aLine)
	{
	if(aValue != aExpected)
		{
		TheTest.Printf(_L("*** Expected error: %d, got: %d\r\n"), aExpected, aValue);
		TheTest(EFalse, aLine);
		}
	}
//Use these to test conditions.
#define TEST(arg) ::Check((arg), __LINE__)
#define TEST2(aValue, aExpected) ::Check(aValue, aExpected, __LINE__)

///////////////////////////////////////////////////////////////////////////////////////

LOCAL_C void setupTestDirectory()
    {// Prepare the test directory.
	TInt r=TheFs.Connect();
	TEST2(r, KErrNone);
//
	r=TheFs.MkDirAll(KTestDir);
	TEST(r==KErrNone||r==KErrAlreadyExists);
	r=TheFs.SetSessionPath(KTestDir);
	TEST2(r, KErrNone);
	}

LOCAL_C void setupCleanup()
    {// Initialise the cleanup stack
	TheTrapCleanup=CTrapCleanup::New();
	TEST(TheTrapCleanup!=NULL);
	TRAPD(r,\
		{\
		for (TInt i=KTestCleanupStack;i>0;i--)\
			CleanupStack::PushL((TAny*)0);\
		CleanupStack::Pop(KTestCleanupStack);\
		});
	TEST2(r, KErrNone);
	}

/**
@SYMTestCaseID          SYSLIB-STORE-CT-1132
@SYMTestCaseDesc	    Setting a larger file size test
@SYMTestPriority 	    High
@SYMTestActions  	    Attempt for opening a large size file.Check for KErrNone flag
@SYMTestExpectedResults Test must not fail
@SYMREQ                 REQ0000
*/
#ifdef _DEBUG
LOCAL_D void SetFileSizeLargerL()
	{
	TheTest.Next(_L(" @SYMTestCaseID:SYSLIB-STORE-CT-1132 "));
	(void)TheFs.Delete(KFileName);
	store=CPermanentFileStore::CreateLC(TheFs,KFileName,EFileWrite|EFileRead);
	store->SetTypeL(KPermanentFileStoreLayoutUid);
	TStreamId rootId = store->ExtendL();
	store->SetRootL(rootId);
	store->CommitL();
	CleanupStack::PopAndDestroy();

	RFile file;
	file.Open(TheFs,KFileName,EFileWrite|EFileRead);
	file.SetSize(100000);
	file.Close();

	TRAPD(r,store=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);CleanupStack::PopAndDestroy();)
	TEST2(r, KErrNone);

	(void)TheFs.Delete(KFileName);
	}
/**
@SYMTestCaseID          SYSLIB-STORE-CT-1133
@SYMTestCaseDesc	    Reducing the file size test
@SYMTestPriority 	    High
@SYMTestActions  	    Attempt for reducing the file size gradually and checking for KErrEof flag on every attempt.
@SYMTestExpectedResults Test must not fail
@SYMREQ                 REQ0000
*/
LOCAL_D void SetFileSizeSmallerL()
	{
	TheTest.Next(_L(" @SYMTestCaseID:SYSLIB-STORE-CT-1133 "));
	(void)TheFs.Delete(KFileName);
	store=CPermanentFileStore::CreateLC(TheFs,KFileName,EFileWrite|EFileRead);
	store->SetTypeL(KPermanentFileStoreLayoutUid);
	TStreamId rootId = store->ExtendL();
	store->SetRootL(rootId);
	store->CommitL();
	CleanupStack::PopAndDestroy();

	store=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);
	TStreamId id2 = out.CreateLC(*store);
	out << alphabet;
	out.CommitL();
	CleanupStack::PopAndDestroy();
	out.ReplaceLC(*store,rootId);
	out << id2;
	out.CommitL();
	CleanupStack::PopAndDestroy();

	store->CommitL();
	CleanupStack::PopAndDestroy();

	store=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);
	CleanupStack::PopAndDestroy();

	RFile file;
	file.Open(TheFs,KFileName,EFileWrite|EFileRead);
	file.SetSize(16);
	file.Close();

	TRAPD(r,store=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);CleanupStack::PopAndDestroy();)
	TEST2(r, KErrEof);

	file.Open(TheFs,KFileName,EFileWrite|EFileRead);
	file.SetSize(3);
	file.Close();

	TRAP(r,store=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);CleanupStack::PopAndDestroy();)
	TEST2(r, KErrEof);

	file.Open(TheFs,KFileName,EFileWrite|EFileRead);
	file.SetSize(1);
	file.Close();

	TRAP(r,store=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);CleanupStack::PopAndDestroy();)
	TEST2(r, KErrEof);

	file.Open(TheFs,KFileName,EFileWrite|EFileRead);
	file.SetSize(0);
	file.Close();

	TRAP(r,store=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);CleanupStack::PopAndDestroy();)
	TEST2(r, KErrEof);

	(void)TheFs.Delete(KFileName);
	}
/**
@SYMTestCaseID          SYSLIB-STORE-CT-1134
@SYMTestCaseDesc	    Opening a corrupt file test
@SYMTestPriority 	    High
@SYMTestActions  	    Attempt for writing garbage text to file and opening the corrupt file.Check for KErrCorrupt flag.
@SYMTestExpectedResults Test must not fail
@SYMREQ                 REQ0000
*/
LOCAL_D void CorruptFileL()
	{
	TheTest.Next(_L(" @SYMTestCaseID:SYSLIB-STORE-CT-1134 "));
	(void)TheFs.Delete(KFileName);
	store=CPermanentFileStore::CreateLC(TheFs,KFileName,EFileWrite|EFileRead);
	store->SetTypeL(KPermanentFileStoreLayoutUid);
	TStreamId rootId = store->ExtendL();
	store->SetRootL(rootId);
	store->CommitL();
	CleanupStack::PopAndDestroy();

	store=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);
	TStreamId id2 = out.CreateLC(*store);
	out << alphabet;
	out.CommitL();
	CleanupStack::PopAndDestroy();
	out.ReplaceLC(*store,rootId);
	out << id2;
	out.CommitL();
	CleanupStack::PopAndDestroy();

	store->CommitL();
	CleanupStack::PopAndDestroy();

	storeCopy=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);
	CleanupStack::PopAndDestroy();
//
	storeCopy=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);
	_LIT8(KGarbage,"garbagegarbagegarbage");
	TInt pos;
	storeCopy->File().Size(pos);
	storeCopy->File().Write(pos-KGarbage().Length(),KGarbage);
	CleanupStack::PopAndDestroy(storeCopy);
//
	TRAPD(r,storeCopy=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);CleanupStack::PopAndDestroy();)
	TEST2(r, KErrCorrupt);

	(void)TheFs.Delete(KFileName);
	}
/**
@SYMTestCaseID          SYSLIB-STORE-CT-1135
@SYMTestCaseDesc	    Corrupting the file to various sizes test
@SYMTestPriority 	    High
@SYMTestActions  	    Attempt for clipping the file to various sizes.Check for KErrCorrupt,KErrNone,KErrEof error flags
                        while opening the corrupt file.
@SYMTestExpectedResults Test must not fail
@SYMREQ                 REQ0000
*/
LOCAL_D void CorruptFileToVariousSizesL()
	{
	TheTest.Next(_L(" @SYMTestCaseID:SYSLIB-STORE-CT-1135 "));
	_LIT(KFileName, "t_storcorrupt1.dat");
	store=CPermanentFileStore::ReplaceLC(TheFs,KFileName,EFileWrite|EFileRead);

	store->SetTypeL(KPermanentFileStoreLayoutUid);
	TStreamId rootIdent = store->ExtendL();
	store->SetRootL(rootIdent);
	store->CommitL();

	TStreamId id5 = out.CreateLC(*store);
	out << alphabet;
	out << id5;
	out.CommitL();
	CleanupStack::PopAndDestroy();//out
	store->CommitL();
	CleanupStack::PopAndDestroy();//store

	TEST2(file.Open(TheFs,KFileName,EFileWrite|EFileRead), KErrNone);
	TInt size;
	TEST2(file.Size(size), KErrNone);
	file.Close();
	const TInt KErrorChange=23;
	for (TInt clip=0;clip<=size;++clip)
		{
		TEST2(file.Open(TheFs,KFileName,EFileWrite|EFileRead) ,KErrNone);
		TEST2(file.SetSize(size-clip), KErrNone);
		file.Close();

		TRAPD(r,
			store=CPermanentFileStore::OpenLC(TheFs,KFileName,EFileWrite|EFileRead);
			CleanupStack::PopAndDestroy();
			)
		if (clip==0)
			TEST2(r, KErrNone);
		else if (clip<KErrorChange)
			TEST2(r, KErrCorrupt);
		else if (clip>=KErrorChange)
			TEST2(r, KErrEof);
		}
	TInt err = TheFs.Delete(KFileName);
	if(err != KErrNone)
		{
		RDebug::Print(_L("Error %d deleting \"%S\" file.\n"), err, &KFileName);
		}
	}

// Is it impossible to CorruptFileWhileWritingStreamsL
/*
LOCAL_D void CorruptFileWhileWritingStreamsL()
	{
	TheFs.Delete(_L("swiss"));
	store=CPermanentFileStore::CreateLC(TheFs,_L("swiss"),EFileWrite|EFileRead);
	store->SetTypeL(KPermanentFileStoreLayoutUid);
	TStreamId rootId = store->ExtendL();
	store->SetRootL(rootId);
	store->CommitL();
	CleanupStack::PopAndDestroy();

	store=CPermanentFileStore::OpenLC(TheFs,_L("swiss"),EFileWrite|EFileRead);CleanupStack::PopAndDestroy();
	store->File().SetSize(3);
	store->File().SetSize(100000);

	TStreamId id3 = out.CreateLC(*store);
	out << alphabet;
	out.CommitL();
	CleanupStack::PopAndDestroy();

	TRAPD(r,store->CommitL();)
	test(r==KErrNone);
	CleanupStack::PopAndDestroy();// store
	}*/
#endif

GLDEF_C TInt E32Main()
    {// Test permanent file store.
	TheTest.Title();
	setupTestDirectory();
	setupCleanup();
#ifdef _DEBUG
	__UHEAP_MARK;
//
	TheTest.Start(_L("Begin tests"));
	TRAPD(r,SetFileSizeLargerL());
	TheTest.Printf(_L("SetFileSizeLargerL()\n"));
	TEST2(r, KErrNone);
	TRAP(r,SetFileSizeSmallerL());
	TheTest.Printf(_L("SetFileSizeSmallerL()\n"));
	TEST2(r, KErrNone);
	TRAP(r,CorruptFileL());
	TheTest.Printf(_L("CorruptFileL()\n"));
	TEST2(r, KErrNone);
	TRAP(r,CorruptFileToVariousSizesL());
	TheTest.Printf(_L("CorruptFileToVariousSizesL()\n"));
	TEST2(r, KErrNone);
//	TRAP(r,CorruptFileWhileWritingStreamsL());
//	test.Console()->Printf(_L("CorruptFileWhileWritingStreamsL()\n"));
//	test(r==KErrNone);
	TheTest.End();
//
	__UHEAP_MARKEND;
#endif

#ifndef _DEBUG
	TheTest.Start(_L("The tests are not valid in release mode"));
	TheTest.End();
#endif
	delete TheTrapCleanup;
	TheFs.Close();
	TheTest.Close();
	return 0;
    }