mmtestenv/mmtestfwunittest/src/tsu_mmtsth03/TSU_MmTsth03.cpp
changeset 0 40261b775718
equal deleted inserted replaced
-1:000000000000 0:40261b775718
       
     1 // Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
       
     2 // All rights reserved.
       
     3 // This component and the accompanying materials are made available
       
     4 // under the terms of "Eclipse Public License v1.0"
       
     5 // which accompanies this distribution, and is available
       
     6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     7 //
       
     8 // Initial Contributors:
       
     9 // Nokia Corporation - initial contribution.
       
    10 //
       
    11 // Contributors:
       
    12 //
       
    13 // Description:
       
    14 // This file contains the test steps for Unit Test Suite 03 : Filename.cpp
       
    15 // 
       
    16 //
       
    17 
       
    18 // EPOC includes
       
    19 #include <e32base.h>
       
    20 
       
    21 // Test system includes
       
    22 #include <testframework.h>
       
    23 
       
    24 // Specific includes for this test suite
       
    25 #include "TSU_MmTsthStep03.h"
       
    26 #include "TSU_MmTsthSuite03.h"
       
    27 
       
    28 // Specific includes for these test steps
       
    29 #include "TSU_MmTsth03.h"
       
    30 #include "TestFramework/Filename.h"
       
    31 
       
    32 // --------------------------------------------
       
    33 
       
    34 // Unit Test Suite 03 : Filename.cpp
       
    35 // Depends on : none
       
    36 
       
    37 // Tests :-
       
    38 // 1. Allocate and deallocate an object
       
    39 // 2. Test assignment overloads
       
    40 // 3. Test copy overloads
       
    41 // 4. Test locate
       
    42 // 5. Test slicing (Left)
       
    43 // 11. Test data scope
       
    44 
       
    45 // ---------------------
       
    46 // RTestMmTsthU0301
       
    47 
       
    48 RTestMmTsthU0301* RTestMmTsthU0301::NewL()
       
    49 	{
       
    50 	RTestMmTsthU0301* self = new(ELeave) RTestMmTsthU0301;
       
    51 	return self;
       
    52 	}
       
    53 
       
    54 // Each test step initialises its own name.
       
    55 RTestMmTsthU0301::RTestMmTsthU0301()
       
    56 	{
       
    57 	iTestStepName = _L("MM-TSTH-U-0301");
       
    58 	}
       
    59 
       
    60 // preamble
       
    61 TVerdict RTestMmTsthU0301::OpenL()
       
    62 	{
       
    63 	// stub - to avoid calling RTestStep_MM_TSTH_U_03::OpenL() which
       
    64 	// initialises iFileName
       
    65 	return iTestStepResult = EPass;
       
    66 	}
       
    67 
       
    68 // postamble
       
    69 void RTestMmTsthU0301::Close()
       
    70 	{
       
    71 	}
       
    72 
       
    73 // do the test step.
       
    74 TVerdict RTestMmTsthU0301::DoTestStepL()
       
    75 	{
       
    76 	// NB this test is the test for NewL() therefore it uses
       
    77 	// a stubbed preamble / postamble
       
    78 	
       
    79 	INFO_PRINTF1(_L("Create a CFileName"));
       
    80 
       
    81 	TVerdict currentVerdict = EPass;
       
    82 
       
    83 	// create a CFileName with NewL
       
    84 	CFileName* theFileName = NULL;
       
    85 	TRAPD(err, theFileName = CFileName::NewL());
       
    86 	if(err != KErrNone)
       
    87 		{
       
    88 		ERR_PRINTF2(_L("CFileName::NewL left with code %d"), err);
       
    89 		return iTestStepResult = EFail;
       
    90 		}
       
    91 	INFO_PRINTF1(_L("CFileName::NewL succeeded"));
       
    92 	delete theFileName;
       
    93 
       
    94 	// create a CFileName with NewLC
       
    95 	CFileName* theLCFileName = NULL;
       
    96 	TRAPD(err2, theLCFileName = CFileName::NewLC();
       
    97 				CleanupStack::Pop(theLCFileName) );
       
    98 	if(err2 != KErrNone)
       
    99 		{
       
   100 		ERR_PRINTF2(_L("CFileName::NewLC left with code %d"), err2);
       
   101 		return iTestStepResult = EFail;
       
   102 		}
       
   103 
       
   104 	INFO_PRINTF1(_L("CFileName::NewLC succeeded"));
       
   105 	delete theLCFileName;
       
   106 	return iTestStepResult = currentVerdict; // should be EPass if we've got here
       
   107 	}
       
   108 
       
   109 // ------------------------
       
   110 // RTestMmTsthU0302
       
   111 RTestMmTsthU0302* RTestMmTsthU0302::NewL()
       
   112 	{
       
   113 	RTestMmTsthU0302* self = new(ELeave) RTestMmTsthU0302;
       
   114 	return self;
       
   115 	}
       
   116 
       
   117 // Each test step initialises its own name.
       
   118 RTestMmTsthU0302::RTestMmTsthU0302()
       
   119 	{
       
   120 	iTestStepName = _L("MM-TSTH-U-0302");
       
   121 	}
       
   122 
       
   123 // do the test step.
       
   124 TVerdict RTestMmTsthU0302::DoTestStepL()
       
   125 	{
       
   126 	const TInt KTestBufSize = 48;	// allocate enough space for test strings
       
   127 
       
   128 	INFO_PRINTF1(_L("Test CFileName assign overloads"));
       
   129 
       
   130 	TVerdict currentVerdict = EPass;
       
   131 
       
   132 	// test against TPtrC
       
   133 	TPtrC testTPtrCStr = _L("Test TPtrC String");
       
   134 	*iFileName = testTPtrCStr;
       
   135 	if(testTPtrCStr != iFileName->FileName())
       
   136 		{
       
   137 		ERR_PRINTF1(_L("CFileName::operator=(const TPtrC&) failed"));
       
   138 		return iTestStepResult = EFail;
       
   139 		}
       
   140 
       
   141 	// test against TDesC
       
   142 	TBufC<KTestBufSize> testTDesCStr = _L("Test TDesC String");
       
   143 	*iFileName = testTDesCStr;
       
   144 	if(testTDesCStr != iFileName->FileName())
       
   145 		{
       
   146 		ERR_PRINTF1(_L("CFileName::operator=(const TDesC&) failed"));
       
   147 		return iTestStepResult = EFail;
       
   148 		}
       
   149 
       
   150 	// test against TFileName
       
   151 	TFileName testTFileNameStr = _L("Test TFileName String");
       
   152 	*iFileName = testTFileNameStr;
       
   153 	if(testTFileNameStr != iFileName->FileName())
       
   154 		{
       
   155 		ERR_PRINTF1(_L("CFileName::operator=(const TFileName&) failed"));
       
   156 		return iTestStepResult = EFail;
       
   157 		}
       
   158 
       
   159 	// test against TText*
       
   160 	const TText* testTTextStr = _S("Test TText String\0");
       
   161 	*iFileName = testTTextStr;
       
   162 	// convert testTTextStr for comparison purposes
       
   163 	TBuf<KTestBufSize> testCompTTextStr(testTTextStr);
       
   164 	if(testCompTTextStr != iFileName->FileName())
       
   165 		{
       
   166 		ERR_PRINTF1(_L("CFileName::operator=(const TText*) failed"));
       
   167 		return iTestStepResult = EFail;
       
   168 		}
       
   169 
       
   170 	// test against self
       
   171 	CFileName* testCFileName = CFileName::NewL();
       
   172 	*testCFileName = _L("Test CFileName String");
       
   173 	*iFileName = *testCFileName;
       
   174 	if(testCFileName->FileName() != iFileName->FileName())
       
   175 		{
       
   176 		ERR_PRINTF1(_L("CFileName::operator=(const CFileName&) failed"));
       
   177 		delete testCFileName;
       
   178 		return iTestStepResult = EFail;
       
   179 		}
       
   180 	delete testCFileName;
       
   181 
       
   182 	return iTestStepResult = currentVerdict; // should be EPass if we've got here
       
   183 
       
   184 	}
       
   185 
       
   186 // ------------------------
       
   187 // RTestMmTsthU0303
       
   188 
       
   189 RTestMmTsthU0303* RTestMmTsthU0303::NewL()
       
   190 	{
       
   191 	RTestMmTsthU0303* self = new(ELeave) RTestMmTsthU0303;
       
   192 	return self;
       
   193 	}
       
   194 
       
   195 // Each test step initialises its own name.
       
   196 RTestMmTsthU0303::RTestMmTsthU0303()
       
   197 	{
       
   198 	iTestStepName = _L("MM-TSTH-U-0303");
       
   199 	}
       
   200 
       
   201 // do the test step.
       
   202 TVerdict RTestMmTsthU0303::DoTestStepL()
       
   203 	{
       
   204 	const TInt KTestBufSize = 48;	// allocate enough space for test strings
       
   205 
       
   206 	INFO_PRINTF1(_L("Test CFileName::Copy"));
       
   207 
       
   208 	TVerdict currentVerdict = EPass;
       
   209 
       
   210 	// test against TDesC8
       
   211 	TBufC8<KTestBufSize> testTDesC8Str = _L8("Test TDesC8 String");
       
   212 	iFileName->Copy(testTDesC8Str);
       
   213 	// convert testTDesC8Str for comparison purposes
       
   214 	TBuf16<KTestBufSize> testCompTDesC8Str = _L16("Test TDesC8 String");
       
   215 	if(testCompTDesC8Str != iFileName->FileName())
       
   216 		{
       
   217 		ERR_PRINTF1(_L("CFileName::Copy(const TDesC8&) failed"));
       
   218 		return iTestStepResult = EFail;
       
   219 		}
       
   220 
       
   221 	// test against TDesC16
       
   222 	TBufC16<KTestBufSize> testTDesC16Str = _L16("Test TDesC16 String");
       
   223 	iFileName->Copy(testTDesC16Str);
       
   224 	if(testTDesC16Str != iFileName->FileName())
       
   225 		{
       
   226 		ERR_PRINTF1(_L("CFileName::Copy(const TDesC16&) failed"));
       
   227 		return iTestStepResult = EFail;
       
   228 		}
       
   229 
       
   230 	// test against TUint16* with length
       
   231 	const TUint16* testTUint16Str = _S16("Test TUint16 String");
       
   232 	// convert testTUint16Str for comparison purposes
       
   233 	TBuf16<KTestBufSize> testCompTUint16Str(testTUint16Str);
       
   234 	iFileName->Copy(testTUint16Str, testCompTUint16Str.Length());
       
   235 	const TDesC& iFileNameLeft = iFileName->FileName().Left(testCompTUint16Str.Length());
       
   236 	if(testCompTUint16Str != iFileNameLeft)
       
   237 		{
       
   238 		ERR_PRINTF1(_L("CFileName::Copy(const TUint16*, int) failed"));
       
   239 		return iTestStepResult = EFail;
       
   240 		}
       
   241 
       
   242 	// test against TUint16* zero terminated
       
   243 	const TUint16* testTUint16ZStr = _S16("Test TUint16Z String\0");
       
   244 	iFileName->Copy(testTUint16ZStr);
       
   245 	// convert testTUint16Str for comparison purposes
       
   246 	TBuf16<KTestBufSize> testCompTUint16ZStr(testTUint16ZStr);
       
   247 	if(testCompTUint16ZStr != iFileName->FileName())
       
   248 		{
       
   249 		ERR_PRINTF1(_L("CFileName::Copy(const TUint16*) failed"));
       
   250 		return iTestStepResult = EFail;
       
   251 		}
       
   252 
       
   253 	return iTestStepResult = currentVerdict; // should be EPass if we've got here
       
   254 
       
   255 	}
       
   256 
       
   257 // ------------------------
       
   258 // RTestMmTsthU0304
       
   259 RTestMmTsthU0304* RTestMmTsthU0304::NewL()
       
   260 	{
       
   261 	RTestMmTsthU0304* self = new(ELeave) RTestMmTsthU0304;
       
   262 	return self;
       
   263 	}
       
   264 
       
   265 // Each test step initialises its own name.
       
   266 RTestMmTsthU0304::RTestMmTsthU0304()
       
   267 	{
       
   268 	iTestStepName = _L("MM-TSTH-U-0304");
       
   269 	}
       
   270 
       
   271 // Do the test step.
       
   272 TVerdict RTestMmTsthU0304::DoTestStepL()
       
   273 	{
       
   274 	INFO_PRINTF1(_L("Test CFileName::Locate"));
       
   275 
       
   276 	TVerdict currentVerdict = EPass;
       
   277 
       
   278 	// test is inconclusive if the assignment fails
       
   279 	TPtrC testLocateStr = _L("ABCDEFG");
       
   280 	*iFileName = testLocateStr;
       
   281 	if(testLocateStr != iFileName->FileName())
       
   282 		{
       
   283 		ERR_PRINTF1(_L("CFileName::operator=(const TPtrC&) failed in Locate Test"));
       
   284 		return iTestStepResult = EInconclusive;
       
   285 		}
       
   286 	TInt rc = iFileName->Locate('C');
       
   287 	if(rc != 2)
       
   288 		{
       
   289 		ERR_PRINTF1(_L("CFileName::Locate() failed"));
       
   290 		return iTestStepResult = EFail;
       
   291 		}
       
   292 	rc = iFileName->Locate('Z');
       
   293 	if(rc != KErrNotFound)
       
   294 		{
       
   295 		ERR_PRINTF1(_L("CFileName::Locate() failed"));
       
   296 		return iTestStepResult = EFail;
       
   297 		}
       
   298 
       
   299 	return iTestStepResult = currentVerdict; // should be EPass if we've got here
       
   300 	}
       
   301 
       
   302 // ------------------------
       
   303 // RTestMmTsthU0305
       
   304 
       
   305 RTestMmTsthU0305* RTestMmTsthU0305::NewL()
       
   306 	{
       
   307 	RTestMmTsthU0305* self = new(ELeave) RTestMmTsthU0305;
       
   308 	return self;
       
   309 	}
       
   310 
       
   311 // Each test step initialises its own name.
       
   312 RTestMmTsthU0305::RTestMmTsthU0305()
       
   313 	{
       
   314 	iTestStepName = _L("MM-TSTH-U-0305");
       
   315 	}
       
   316 
       
   317 // Do the test step.
       
   318 TVerdict RTestMmTsthU0305::DoTestStepL()
       
   319 	{
       
   320 	INFO_PRINTF1(_L("Test CFileName::Left"));
       
   321 
       
   322 	TVerdict currentVerdict = EPass;
       
   323 
       
   324 	// test is inconclusive if the assignment fails
       
   325 	TPtrC testLocateStr = _L("ABCDEFG");
       
   326 	*iFileName = testLocateStr;
       
   327 	if(testLocateStr != iFileName->FileName())
       
   328 		{
       
   329 		ERR_PRINTF1(_L("CFileName::operator=(const TPtrC&) failed in Locate Test"));
       
   330 		return iTestStepResult = EInconclusive;
       
   331 		}
       
   332 	const TFileName& iFileNameLeft = iFileName->Left(3);
       
   333 	TPtrC testLeftStr = _L("ABC");
       
   334 
       
   335 	if(testLeftStr != iFileNameLeft)
       
   336 		{
       
   337 		ERR_PRINTF1(_L("CFileName::Left() failed"));
       
   338 		return iTestStepResult = EFail;
       
   339 		}
       
   340 
       
   341 	return iTestStepResult = currentVerdict; // should be EPass if we've got here
       
   342 
       
   343 	}
       
   344 
       
   345 // ------------------------
       
   346 // RTestMmTsthU0311
       
   347 RTestMmTsthU0311* RTestMmTsthU0311::NewL()
       
   348 	{
       
   349 	RTestMmTsthU0311* self = new(ELeave) RTestMmTsthU0311;
       
   350 	return self;
       
   351 	}
       
   352 
       
   353 // Each test step initialises its own name.
       
   354 RTestMmTsthU0311::RTestMmTsthU0311()
       
   355 	{
       
   356 	iTestStepName = _L("MM-TSTH-U-0311");
       
   357 	}
       
   358 
       
   359 // Do the test step.
       
   360 TVerdict RTestMmTsthU0311::DoTestStepL()
       
   361 	{
       
   362 	const TInt KTestBufSize = 48;	// allocate enough space for test strings
       
   363 
       
   364 	INFO_PRINTF1(_L("Test CFileName memory scope"));
       
   365 
       
   366 	TVerdict currentVerdict = EPass;
       
   367 
       
   368 	// send original copied string out of scope, to prove that CFileName
       
   369 	// is using its own data space
       
   370 	TPtr16 testDynTDesCStr(REINTERPRET_CAST(TUint16*,User::AllocLC(KTestBufSize*2)), 0, KTestBufSize);
       
   371 	testDynTDesCStr = _L("Test TDesC String");
       
   372 	*iFileName = testDynTDesCStr;
       
   373 
       
   374 	CleanupStack::PopAndDestroy(); // testDynTDesCStr
       
   375 
       
   376 	// if iFileName->FileName() is out of scope, this will panic with USER 7. If it doesn't, we've passed
       
   377 	TPtrC resStr = iFileName->FileName();
       
   378 	INFO_PRINTF2(_L("CFileName::FileName() is '%S'"), &resStr);
       
   379 
       
   380 	return iTestStepResult = currentVerdict; // should be EPass if we've got here
       
   381 
       
   382 	}