kerneltest/f32test/server/t_notify.cpp
changeset 0 a41df078684a
child 43 c1f20ce4abcf
equal deleted inserted replaced
-1:000000000000 0:a41df078684a
       
     1 // Copyright (c) 1996-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 the License "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 // f32test\server\t_notify.cpp
       
    15 // 
       
    16 //
       
    17 
       
    18 #include <f32file.h>
       
    19 #include <e32test.h>
       
    20 #include <e32svr.h>
       
    21 #include <hal.h>
       
    22 #include "t_server.h"
       
    23 
       
    24 const TInt KHeapSize=0x200;
       
    25 
       
    26 // wait for a bit since NotifyChange handled asynchronously and SetDriveName synchronously
       
    27 const TInt KNotifyChangeAfter=100000;
       
    28 const TInt KMediaRemountForceMediaChange = 0x00000001;
       
    29 
       
    30 RTest test(_L("T_NOTIFY"));
       
    31 RSemaphore gSleepThread;
       
    32 TInt gSocketNumber=0;
       
    33 TInt SocketToDrive[KMaxPBusSockets];
       
    34 
       
    35 //#define __INCLUDE_MANUAL_TESTS__
       
    36 
       
    37 void do_check_no_pending_requests(TInt aLine)
       
    38 	{
       
    39 	RTimer timer;
       
    40 	TRequestStatus timerStat;
       
    41 	timer.CreateLocal();
       
    42 	timer.After(timerStat, 125000);
       
    43 	User::WaitForAnyRequest();
       
    44 	if(timerStat==KRequestPending)
       
    45 		{
       
    46 		RDebug::Printf("do_check_no_pending_requests failed at line %d",aLine);
       
    47 		test(0);
       
    48 		}
       
    49 	timer.Close();
       
    50 	}
       
    51 #define CHECK_NO_PENDING_REQUESTS do_check_no_pending_requests(__LINE__);
       
    52 
       
    53 
       
    54 TBool CheckDriveRead(TInt aDrive)
       
    55   //Determines if can connect to local drive number and read
       
    56 	{
       
    57     TBusLocalDrive TBLD;
       
    58     TBool TBLDChangedFlag;
       
    59 
       
    60     TInt r = TBLD.Connect(aDrive, TBLDChangedFlag);
       
    61 	test.Printf(_L("Connect returned %d\n"), r);
       
    62     if (r == KErrNone)
       
    63 		{
       
    64         const TInt KSectSize = 512;
       
    65         TBuf8<KSectSize> sect;
       
    66         r = TBLD.Read(0, KSectSize, sect);
       
    67 		test.Printf(_L("Read returned %d\n"), r);
       
    68         TBLD.Disconnect();
       
    69 		if(r!=KErrNone)
       
    70 			return EFalse;
       
    71 		else
       
    72 			return ETrue;
       
    73         }
       
    74 	 else
       
    75 		return EFalse;
       
    76 	}
       
    77 
       
    78 void GenerateMediaChange()
       
    79 	{
       
    80     TPckgBuf<TInt> pckg;
       
    81     pckg()=0;
       
    82 
       
    83 	RFs fs;
       
    84 	TInt r = fs.Connect();
       
    85 	if (r == KErrNone)
       
    86 		{
       
    87 		r = fs.RemountDrive(CurrentDrive(), &pckg, (TUint)KMediaRemountForceMediaChange);
       
    88 		if(r == KErrNotReady)
       
    89 			{
       
    90 			r = KErrNone;
       
    91 			}
       
    92 		fs.Close();
       
    93 		}
       
    94 
       
    95 	if (r!=KErrNone)
       
    96 		{
       
    97 		RProcess me;
       
    98 		me.Panic(_L("GenMedChg"),r);
       
    99 		}
       
   100 	}
       
   101 
       
   102 enum TTestCode {ETest1,ETest2,ETest3,ETest4,ETest5,ETest6,ETest7,ETest8,ETest9,ETest10,ETest11,ETest12};
       
   103 const TUint KGenericEntryChange=0x02;
       
   104 
       
   105 static TInt ThreadEntryPoint(TAny* aTestCode)
       
   106 //
       
   107 // Thread entry point
       
   108 //
       
   109 	{
       
   110 	RFs fs;
       
   111 	TInt r=fs.Connect();
       
   112 	test(r==KErrNone);
       
   113 	r=fs.SetSessionPath(gSessionPath);
       
   114 	test(r==KErrNone);
       
   115 	TTestCode testCode=*(TTestCode*)&aTestCode;
       
   116 	RFile f;
       
   117 	switch (testCode)
       
   118 		{
       
   119 
       
   120 	case ETest1:
       
   121 		r=f.Replace(fs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileStream);
       
   122 		test(r==KErrNone);
       
   123 		f.Close();
       
   124 		break;
       
   125 
       
   126 	case ETest2:
       
   127 		r=f.Replace(fs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileStream);
       
   128 		test(r==KErrNone);
       
   129 		f.Close();
       
   130 		break;
       
   131 
       
   132 	case ETest3:
       
   133 		r=fs.MkDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\SCARECROW\\"));
       
   134 		test((r==KErrNone)||(r==KErrAlreadyExists));
       
   135 		break;
       
   136 
       
   137 	case ETest4:
       
   138 		{
       
   139 		TRequestStatus s;
       
   140 		fs.NotifyChange(ENotifyAll,s);
       
   141 		test(s==KRequestPending);
       
   142 		gSleepThread.Signal();
       
   143 		User::After(100000000);
       
   144 		}
       
   145 		break;
       
   146 
       
   147 	case ETest5:
       
   148 		{
       
   149 		RFile file;
       
   150 		TInt r=file.Open(fs,_L("\\F32-TST\\NOTIFY\\kangaroo.txt"),EFileRead|EFileWrite);
       
   151 		test(r==KErrNone);
       
   152 		r=file.SetSize(sizeof(TCheckedUid));
       
   153 		test(r==KErrNone);
       
   154 		r=file.Write(sizeof(TCheckedUid),_L8("012345678912"));
       
   155 		test(r==KErrNone);
       
   156 		TBuf8<64> dum;
       
   157 		r=file.Read(0,dum);
       
   158 		test(r==KErrNone);
       
   159 		file.Close();
       
   160 
       
   161 		r=file.Open(fs,_L("\\F32-TST\\NOTIFY\\koala.txt"),EFileRead|EFileWrite);
       
   162 		test(r==KErrNone);
       
   163 		r=file.SetSize(50);
       
   164 		test(r==KErrNone);
       
   165 		r=file.Write(sizeof(TCheckedUid),_L8("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
       
   166 		test(r==KErrNone);
       
   167 		r=file.Read(0,dum);
       
   168 		test(r==KErrNone);
       
   169 		file.Close();
       
   170 
       
   171 		r=file.Open(fs,_L("\\F32-TST\\NOTIFY\\dingo.txt"),EFileRead|EFileWrite);
       
   172 		test(r==KErrNone);
       
   173 		r=file.SetSize(50);
       
   174 		test(r==KErrNone);
       
   175 		r=file.Write(sizeof(TCheckedUid),_L8("01234567890123456789"));
       
   176 		test(r==KErrNone);
       
   177 		r=file.Read(0,dum);
       
   178 		test(r==KErrNone);
       
   179 		file.Close();
       
   180 		gSleepThread.Signal();
       
   181 		}
       
   182 		break;
       
   183 
       
   184 	case ETest6:
       
   185 		{
       
   186 		GenerateMediaChange();
       
   187 		User::After(300000);			// Wait for a bit
       
   188 		gSleepThread.Signal();
       
   189 		}
       
   190 		break;
       
   191 
       
   192 	case ETest7:
       
   193 		{
       
   194 		RFile file;
       
   195 		TInt r=file.Open(fs,_L("\\F32-TST\\NOTIFY\\NewFILE.TXT"),EFileRead|EFileWrite);
       
   196 		test(r==KErrNone);
       
   197 		r=file.Write(_L8("asdfasdfasdf"));
       
   198 		test(r==KErrNone);
       
   199 		file.Close();
       
   200 		gSleepThread.Signal();
       
   201 		}
       
   202 		break;
       
   203 
       
   204 	case ETest8:
       
   205 		{
       
   206 		r=f.Open(fs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\WickedWitch.msg"),EFileRead|EFileWrite);
       
   207 		test(r==KErrNone);
       
   208 		f.SetSize(500);
       
   209 		f.Close();
       
   210 		break;
       
   211 		}
       
   212 
       
   213 	case ETest9:
       
   214 		{
       
   215 		TRequestStatus s;
       
   216 		TFileName path=_L("\\F32-TST\\NOTIFY\\");
       
   217 		fs.NotifyChange(ENotifyAll,s,path);
       
   218 		test(s==KRequestPending);
       
   219 		gSleepThread.Signal();
       
   220 		User::After(100000000);
       
   221 		}
       
   222 		break;
       
   223 	case ETest10:
       
   224 		{
       
   225 		TFileName path=_L("\\F32-TST\\NOTIFY\\BehindTheCurtain\\");
       
   226 		r=fs.MkDir(path);
       
   227 		test(r==KErrNone);
       
   228 		break;
       
   229 		}
       
   230 	case ETest11:
       
   231 		{
       
   232 		TFileName path=_L("\\F32-TST\\NOTIFY\\BehindTheCurtain\\PayNoAttention.man");
       
   233 		RFile file;
       
   234 		r=file.Replace(fs,path,EFileStream);
       
   235 		test(r==KErrNone);
       
   236 		file.Close();
       
   237 		break;
       
   238 		}
       
   239 	case ETest12:
       
   240 		{
       
   241 		RFile writer;
       
   242 		TInt r=writer.Open(fs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileWrite|EFileShareAny);
       
   243 		test(r==KErrNone);
       
   244 		TInt i;
       
   245 		for(i=0; i<10; i++)
       
   246 			{
       
   247 			r=writer.Write(_L8("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
       
   248 			test(r==KErrNone);
       
   249 			User::After(1000000);
       
   250 			}
       
   251 		writer.Close();
       
   252 		break;
       
   253 		}
       
   254 	default:
       
   255 		break;
       
   256 		}
       
   257 	return KErrNone;
       
   258 	}
       
   259 
       
   260 #if defined (__EPOC32__)//we have no removable media on Emulator yet
       
   261 static void WaitForMediaChange()
       
   262 //
       
   263 // Wait for media driver to register drive is present
       
   264 //
       
   265 	{
       
   266 
       
   267 	TEntry entry;
       
   268 	FOREVER
       
   269 		{
       
   270 		User::After(10000);
       
   271 		TInt r=TheFs.Entry(_L("xxxxxxxx"),entry);
       
   272 		if (r!=KErrNotReady)
       
   273 			break;
       
   274 		}
       
   275 	}
       
   276 #endif
       
   277 
       
   278 static void Test1()
       
   279 //
       
   280 // Test notification of an entry change
       
   281 //
       
   282 	{
       
   283 
       
   284 	test.Next(_L("Test notification of an entry change"));
       
   285 	TRequestStatus reqStat(KRequestPending);
       
   286 	TRequestStatus thrdStat(KRequestPending);
       
   287 	TInt r;
       
   288 	TheFs.NotifyChange(ENotifyEntry,reqStat);
       
   289 	RThread thread;
       
   290 	r=thread.Create(_L("MyThread"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest1);
       
   291 	test(r==KErrNone);
       
   292 	thread.Logon(thrdStat);
       
   293 	thread.Resume();
       
   294 	User::WaitForRequest(thrdStat);
       
   295 	test(thrdStat==KErrNone);
       
   296 	thread.Close();
       
   297 	User::WaitForRequest(reqStat);
       
   298 	test(reqStat==KErrNone);
       
   299 
       
   300 	RFile file;
       
   301 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileWrite|EFileShareExclusive);
       
   302 	test(r==KErrNone);
       
   303 	file.Write(_L8("Somewhere over the rainbow..."),reqStat);
       
   304 	User::WaitForRequest(reqStat);
       
   305 	test(reqStat==KErrNone);
       
   306 	TBuf8<256> buf;
       
   307 	file.Read(0, buf,reqStat);
       
   308 	User::WaitForRequest(reqStat);
       
   309 	test(reqStat==KErrNone);
       
   310 	file.Close();
       
   311 
       
   312 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileShareExclusive);
       
   313 	test(r==KErrArgument);
       
   314 
       
   315 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileShareReadersOnly);
       
   316 	test(r==KErrArgument);
       
   317 
       
   318 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileShareAny);
       
   319 	test(r==KErrNone);
       
   320 	file.Read(0, buf, 100, reqStat);
       
   321 	test(reqStat==KRequestPending);
       
   322 	file.Close();
       
   323 	User::WaitForRequest(reqStat);
       
   324 	test(reqStat==KErrCancel);
       
   325 
       
   326 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileShareAny);
       
   327 	test(r==KErrNone);
       
   328 	file.Read(0, buf, 100, reqStat);
       
   329 	test(reqStat==KRequestPending);
       
   330 	file.ReadCancel(reqStat);
       
   331 	User::WaitForRequest(reqStat);
       
   332 	test(reqStat==KErrCancel);
       
   333 	file.Close();
       
   334 
       
   335 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileWrite|EFileShareAny);
       
   336 	test(r==KErrNone);
       
   337 	file.Read(0, buf, 100, reqStat);
       
   338 	test(reqStat==KRequestPending);
       
   339 	file.SetSize(100);
       
   340 	User::WaitForRequest(reqStat);
       
   341 	test(reqStat==KErrNone);
       
   342 	test(buf.Length() == 100);
       
   343 	file.Close();
       
   344 
       
   345 	test.Next(_L("Repeat Test notification of an entry change"));
       
   346 	TheFs.NotifyChange(ENotifyEntry,reqStat);
       
   347 	thread.Create(_L("MyThread2"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest1);
       
   348 	thread.Logon(thrdStat);
       
   349 	thread.Resume();
       
   350 	User::WaitForRequest(thrdStat);
       
   351 	test(thrdStat==KErrNone);
       
   352 	thread.Close();
       
   353 	User::WaitForRequest(reqStat);
       
   354 	if (reqStat!=KErrNone)
       
   355 		{
       
   356 		test.Printf(_L("ReqStat=%d\n"),reqStat.Int());
       
   357 		//test.Getch();
       
   358 		}
       
   359 	test(reqStat==KErrNone);
       
   360 
       
   361 	test.Next(_L("Test Notify cancel"));
       
   362 	TheFs.NotifyChange(ENotifyEntry,reqStat);
       
   363 	TheFs.NotifyChangeCancel();
       
   364 	User::WaitForRequest(reqStat);
       
   365 
       
   366 	test.Next(_L("Test notification still works"));
       
   367 	TheFs.NotifyChange(ENotifyEntry,reqStat);
       
   368 	thread.Create(_L("MyThread3"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest1);
       
   369 	thread.Logon(thrdStat);
       
   370 	thread.Resume();
       
   371 	User::WaitForRequest(thrdStat);
       
   372 	test(thrdStat==KErrNone);
       
   373 	thread.Close();
       
   374 	User::WaitForRequest(reqStat);
       
   375 	test(reqStat==KErrNone);
       
   376 	}
       
   377 
       
   378 static void Test2()
       
   379 //
       
   380 // Test notify for multiple clients
       
   381 //
       
   382 	{
       
   383 
       
   384 	test.Next(_L("Test notification of multiple clients"));
       
   385 
       
   386 	TRequestStatus reqStat1(KRequestPending);
       
   387 	RFs fs1;
       
   388 	TInt r=fs1.Connect();
       
   389 	test(r==KErrNone);
       
   390 	fs1.NotifyChange(ENotifyEntry,reqStat1);
       
   391 
       
   392 	TRequestStatus reqStat2(KRequestPending);
       
   393 	RFs fs2;
       
   394 	r=fs2.Connect();
       
   395 	test(r==KErrNone);
       
   396 	fs2.NotifyChange(ENotifyEntry,reqStat2);
       
   397 
       
   398 	test(reqStat1==KRequestPending);
       
   399 	test(reqStat2==KRequestPending);
       
   400 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\NEWFILE.TXT"));
       
   401 	test(r==KErrNone);
       
   402 	User::WaitForRequest(reqStat1);
       
   403 	User::WaitForRequest(reqStat2);
       
   404 	test(reqStat1==KErrNone);
       
   405 	test(reqStat2==KErrNone);
       
   406 	}
       
   407 
       
   408 static void Test3()
       
   409 //
       
   410 // Test notify cancel
       
   411 //
       
   412 	{
       
   413 
       
   414 	test.Next(_L("Cancel notification"));
       
   415 	RFs fs1;
       
   416 	TInt r=fs1.Connect();
       
   417 	test(r==KErrNone);
       
   418 
       
   419 	TRequestStatus status1;
       
   420 	TRequestStatus status2;
       
   421 	TRequestStatus status3;
       
   422 	TRequestStatus status4;
       
   423 	TRequestStatus status5;
       
   424 
       
   425 	fs1.NotifyChange(ENotifyAll,status1);
       
   426 	fs1.NotifyChange(ENotifyAll,status2);
       
   427 	fs1.NotifyChange(ENotifyAll,status3);
       
   428 	fs1.NotifyChange(ENotifyAll,status4);
       
   429 	fs1.NotifyChange(ENotifyAll,status5);
       
   430 	test(status1==KRequestPending);
       
   431 	test(status2==KRequestPending);
       
   432 	test(status3==KRequestPending);
       
   433 	test(status4==KRequestPending);
       
   434 	test(status5==KRequestPending);
       
   435 
       
   436 	test.Next(_L("RFs::NotifyCancel()"));
       
   437 //	Test that one call to RFs::NotifyCancel() cancels all outstanding requests
       
   438 	fs1.NotifyChangeCancel();
       
   439 	User::WaitForRequest(status1);
       
   440 	test(status1==KErrCancel);
       
   441 	User::WaitForRequest(status2);
       
   442 	test(status2==KErrCancel);
       
   443 	User::WaitForRequest(status3);
       
   444 	test(status3==KErrCancel);
       
   445 	User::WaitForRequest(status4);
       
   446 	test(status4==KErrCancel);
       
   447 	User::WaitForRequest(status5);
       
   448 	test(status5==KErrCancel);
       
   449 //	Call the cancel function again to check no further action
       
   450 	fs1.NotifyChangeCancel();
       
   451 
       
   452 //	Test overloaded function to cancel a single request
       
   453 	test.Next(_L("Cancel notification request using function overload"));
       
   454 	fs1.NotifyChange(ENotifyAll,status1);
       
   455 	fs1.NotifyChange(ENotifyAll,status2);
       
   456 	fs1.NotifyChange(ENotifyAll,status3);
       
   457 	fs1.NotifyChange(ENotifyAll,status4);
       
   458 	fs1.NotifyChange(ENotifyAll,status5);
       
   459 	test(status1==KRequestPending);
       
   460 	test(status2==KRequestPending);
       
   461 	test(status3==KRequestPending);
       
   462 	test(status4==KRequestPending);
       
   463 	test(status5==KRequestPending);
       
   464 
       
   465 //	Cancel the outstanding request with status5
       
   466 	test.Next(_L("RFs::NotifyCancel()"));
       
   467 	fs1.NotifyChangeCancel(status5);
       
   468 	User::WaitForRequest(status5);
       
   469 	test(status1==KRequestPending);
       
   470 	test(status2==KRequestPending);
       
   471 	test(status3==KRequestPending);
       
   472 	test(status4==KRequestPending);
       
   473 	test(status5==KErrCancel);
       
   474 
       
   475 	fs1.NotifyChangeCancel(status2);
       
   476 	User::WaitForRequest(status2);
       
   477 
       
   478 	test(status1==KRequestPending);
       
   479 	test(status2==KErrCancel);
       
   480 	test(status3==KRequestPending);
       
   481 	test(status4==KRequestPending);
       
   482 
       
   483 	fs1.NotifyChangeCancel(status4);
       
   484 	User::WaitForRequest(status4);
       
   485 	test(status1==KRequestPending);
       
   486 	test(status3==KRequestPending);
       
   487 	test(status4==KErrCancel);
       
   488 
       
   489 	fs1.NotifyChangeCancel(status4);	//	Test no side effects on trying to cancel a request
       
   490 	test(status4==KErrCancel);			//	that has already been cancelled
       
   491 
       
   492 	fs1.NotifyChangeCancel(status1);
       
   493 	User::WaitForRequest(status1);
       
   494 	test(status1==KErrCancel);
       
   495 	test(status3==KRequestPending);
       
   496 	fs1.NotifyChangeCancel(status1);	//	Test no side effects on trying to cancel a request
       
   497 	test(status1==KErrCancel);			//	that has already been cancelled
       
   498 
       
   499 	fs1.NotifyChangeCancel(status3);
       
   500 	User::WaitForRequest(status3);
       
   501 	test(status3==KErrCancel);
       
   502 
       
   503 	fs1.Close();
       
   504 	}
       
   505 
       
   506 static void Test4()
       
   507 //
       
   508 // Test notify client death
       
   509 //
       
   510 	{
       
   511 
       
   512 	test.Next(_L("Kill client"));
       
   513 	TInt r=gSleepThread.CreateLocal(0);
       
   514 	test(r==KErrNone);
       
   515 	RThread clientThread;
       
   516 	r=clientThread.Create(_L("ClientThread"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest4);
       
   517 	if (r!=KErrNone)
       
   518 		{
       
   519 		test.Printf(_L(" ERROR: Failed to create clientthread %d\n"),r);
       
   520 		test(0);
       
   521 		//test.Getch();
       
   522 		return;
       
   523 		}
       
   524 	clientThread.Resume();
       
   525 	gSleepThread.Wait();
       
   526 
       
   527 	TBool jit = User::JustInTime();
       
   528 	User::SetJustInTime(EFalse);
       
   529 	clientThread.Panic(_L("Test client thread panic"),KErrGeneral);
       
   530 	User::SetJustInTime(jit);
       
   531 
       
   532 	clientThread.Close();
       
   533 
       
   534 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\"));
       
   535 	test(r==KErrNone || r==KErrAlreadyExists);
       
   536 	MakeFile(_L("\\F32-TST\\NOTIFY\\NewFile.Txt"));
       
   537 	User::After(1000);
       
   538 	}
       
   539 
       
   540 static void Test5()
       
   541 //
       
   542 // Test reads and writes do not cause notification
       
   543 //
       
   544 	{
       
   545 
       
   546 	test.Next(_L("Test reads and writes do not cause notification"));
       
   547 
       
   548 
       
   549 	RFile file;
       
   550 	TInt r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\kangaroo.txt"),EFileRead|EFileWrite);
       
   551 	test(r==KErrNone);
       
   552 	file.Close();
       
   553 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\koala.txt"),EFileRead|EFileWrite);
       
   554 	test(r==KErrNone);
       
   555 	file.Close();
       
   556 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\dingo.txt"),EFileRead|EFileWrite);
       
   557 	test(r==KErrNone);
       
   558 	file.Close();
       
   559 
       
   560 	TRequestStatus reqStat=0;
       
   561 	TheFs.NotifyChange(ENotifyEntry,reqStat);
       
   562 	test(reqStat==KRequestPending);
       
   563 
       
   564 	r=gSleepThread.CreateLocal(0);
       
   565 	test(r==KErrNone);
       
   566 	RThread clientThread;
       
   567 	r=clientThread.Create(_L("Test5Thread"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest5);
       
   568 	test(r==KErrNone);
       
   569 	clientThread.Resume();
       
   570 	gSleepThread.Wait();
       
   571 	test(reqStat==KRequestPending);
       
   572 
       
   573 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\kangaroo.txt"));
       
   574 	test(r==KErrNone);
       
   575 	User::WaitForRequest(reqStat);
       
   576 	test(reqStat==KErrNone);
       
   577 
       
   578 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\koala.txt"));
       
   579 	test(r==KErrNone);
       
   580 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\dingo.txt"));
       
   581 	test(r==KErrNone);
       
   582 
       
   583 
       
   584 
       
   585 	gSleepThread.Close();
       
   586 	clientThread.Close();
       
   587 	}
       
   588 
       
   589 #if defined (__EPOC32__)//we have no removable media on Emulator yet	.. ??? we do now
       
   590 static void Test6()
       
   591 //
       
   592 //	Test media change notification
       
   593 //
       
   594 	{
       
   595 	TDriveInfo driveInfo;
       
   596 	TInt r=TheFs.Drive(driveInfo,CurrentDrive());
       
   597 	test(r==KErrNone);
       
   598 	// only test on removable media
       
   599 	if (driveInfo.iDriveAtt&KDriveAttRemovable)
       
   600         {
       
   601         TBuf<64> b;
       
   602         b.Format(_L("Test Media change notification (socket:%d)"),gSocketNumber);
       
   603         test.Next(b);
       
   604         TRequestStatus reqStat=0;
       
   605         TInt r;
       
   606         TheFs.NotifyChange(ENotifyEntry,reqStat);
       
   607         test(reqStat==KRequestPending);
       
   608         r=gSleepThread.CreateLocal(0);
       
   609         test(r==KErrNone);
       
   610         RThread clientThread;
       
   611         r=clientThread.Create(_L("Test6Thread"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest6);
       
   612         test(r==KErrNone);
       
   613         clientThread.Resume();
       
   614         gSleepThread.Wait();
       
   615         TInt reqInt=reqStat.Int();
       
   616         test(reqInt==KErrNone);
       
   617         User::WaitForRequest(reqStat);
       
   618         WaitForMediaChange();
       
   619         gSleepThread.Close();
       
   620         clientThread.Close();
       
   621         }
       
   622 	
       
   623         //-- it seems that after generating media change the meia driver isn't ready for some time
       
   624         User::After(2000000);
       
   625 	    r=TheFs.Drive(driveInfo,CurrentDrive());
       
   626 	    test(r==KErrNone);
       
   627 
       
   628     
       
   629     }
       
   630 #endif
       
   631 
       
   632 static void Test7()
       
   633 //
       
   634 // Test Write to uid region does not trigger notification
       
   635 //
       
   636 	{
       
   637 
       
   638 	test.Next(_L("Test Write to uid region does not trigger notification"));
       
   639 	TRequestStatus reqStat=0;
       
   640 	MakeFile(_L("NewFile.TXT"));
       
   641 	TInt r;
       
   642 	TheFs.NotifyChange(ENotifyEntry,reqStat);
       
   643 	test(reqStat==KRequestPending);
       
   644 
       
   645 	r=gSleepThread.CreateLocal(0);
       
   646 	test(r==KErrNone);
       
   647 	RThread clientThread;
       
   648 	r=clientThread.Create(_L("Test7Thread"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest7);
       
   649 	test(r==KErrNone);
       
   650 	clientThread.Resume();
       
   651 	gSleepThread.Wait();
       
   652 	test(reqStat==KRequestPending);
       
   653 
       
   654 	r=TheFs.Delete(_L("Newfile.txt"));
       
   655 	test(r==KErrNone);
       
   656 
       
   657 	User::WaitForRequest(reqStat);
       
   658 
       
   659 	gSleepThread.Close();
       
   660 	clientThread.Close();
       
   661 	}
       
   662 
       
   663 #if defined (__EPOC32__)//we have no removable media on Emulator yet
       
   664 static void MediaChangeExtendedNotification()
       
   665 //
       
   666 //	Test media change notification
       
   667 //	Always notified of media change - regardless of requested TNotifyType
       
   668 //
       
   669 	{
       
   670 	TDriveInfo driveInfo;
       
   671 	TInt r=TheFs.Drive(driveInfo,CurrentDrive());
       
   672 	test(r==KErrNone);
       
   673 	// only test on removable media
       
   674 	if (driveInfo.iDriveAtt&KDriveAttRemovable)
       
   675 		{
       
   676 		test.Next(_L("Test Media change extended notification"));
       
   677 		TRequestStatus reqStat=0;
       
   678 		TFileName path = _L("\\F32-tst\\NOTIFY\\");
       
   679 		TInt r;
       
   680 		TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
   681 		test(reqStat==KRequestPending);
       
   682 		r=gSleepThread.CreateLocal(0);
       
   683 		test(r==KErrNone);
       
   684 		RThread clientThread;
       
   685 		gSocketNumber=0;
       
   686 		r=clientThread.Create(_L("Test6Thread1"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest6);	//only generates a media change on removable media
       
   687 		test(r==KErrNone);
       
   688 		clientThread.Resume();
       
   689 		gSleepThread.Wait();
       
   690 		User::WaitForRequest(reqStat);
       
   691 		test(reqStat==KErrNone);
       
   692 		WaitForMediaChange();
       
   693 		gSleepThread.Close();
       
   694 		clientThread.Close();
       
   695 
       
   696         //-- it seems that after generating media change the meia driver isn't ready for some time
       
   697         User::After(2000000);
       
   698 	    r=TheFs.Drive(driveInfo,CurrentDrive());
       
   699 	    test(r==KErrNone);
       
   700 
       
   701 
       
   702 		TheFs.NotifyChange(ENotifyDisk,reqStat,path);
       
   703 		test(reqStat==KRequestPending);
       
   704 		r=gSleepThread.CreateLocal(0);
       
   705 		test(r==KErrNone);
       
   706 		r=clientThread.Create(_L("Test6Thread2"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest6);
       
   707 		test(r==KErrNone);
       
   708 		clientThread.Resume();
       
   709 		gSleepThread.Wait();
       
   710 		User::WaitForRequest(reqStat);
       
   711 		test(reqStat==KErrNone);
       
   712 		WaitForMediaChange();
       
   713 		gSleepThread.Close();
       
   714 		clientThread.Close();
       
   715 
       
   716         //-- it seems that after generating media change the meia driver isn't ready for some time
       
   717         User::After(2000000);
       
   718 	    r=TheFs.Drive(driveInfo,CurrentDrive());
       
   719 	    test(r==KErrNone);
       
   720 
       
   721 		TheFs.NotifyChange(ENotifyWrite,reqStat,path);
       
   722 		test(reqStat==KRequestPending);
       
   723 		r=gSleepThread.CreateLocal(0);
       
   724 		test(r==KErrNone);
       
   725 		r=clientThread.Create(_L("Test6Thread3"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest6);
       
   726 		test(r==KErrNone);
       
   727 		clientThread.Resume();
       
   728 		gSleepThread.Wait();
       
   729 		User::WaitForRequest(reqStat);
       
   730 		test(reqStat==KErrNone);
       
   731 		WaitForMediaChange();
       
   732 		gSleepThread.Close();
       
   733 		clientThread.Close();
       
   734 
       
   735         //-- it seems that after generating media change the meia driver isn't ready for some time
       
   736         User::After(2000000);
       
   737 	    r=TheFs.Drive(driveInfo,CurrentDrive());
       
   738 	    test(r==KErrNone);
       
   739 
       
   740 		}
       
   741 	}
       
   742 #endif
       
   743 
       
   744 static void TestRequestAhead()
       
   745 //
       
   746 //	Test extended notification works when path initially does not exist
       
   747 //
       
   748 	{
       
   749 	test.Next(_L("Test Request Ahead"));
       
   750 //	First a simple example
       
   751 
       
   752 	TInt r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\BehindTheCurtain\\"));
       
   753 	test((r==KErrNotFound)||(r==KErrPathNotFound)||(r==KErrNone));
       
   754 
       
   755 	TFileName path=_L("\\F32-TST\\NOTIFY\\BehindTheCurtain\\");
       
   756 	TRequestStatus reqStat(KRequestPending);
       
   757 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
   758 	test(reqStat==KRequestPending);
       
   759 
       
   760 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\BehindTheCurtain\\"));
       
   761 	test(r==KErrNone);
       
   762 
       
   763 	User::WaitForRequest(reqStat);
       
   764 	test(reqStat==KErrNone);
       
   765 
       
   766 	path=_L("\\F32-TST\\NOTIFY\\BehindTheCurtain\\PayNoAttention.man");
       
   767 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
   768 	test(reqStat==KRequestPending);
       
   769 
       
   770 	RFile file;
       
   771 	r=file.Replace(TheFs,path,EFileStream);
       
   772 	test(r==KErrNone);
       
   773 	file.Close();
       
   774 
       
   775 	User::WaitForRequest(reqStat);
       
   776 	test(reqStat==KErrNone);
       
   777 
       
   778 	r=TheFs.Delete(path);
       
   779 	test(r==KErrNone);
       
   780 
       
   781 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
   782 	test(reqStat==KRequestPending);
       
   783 //	Now cancel the outstanding request
       
   784 	TheFs.NotifyChangeCancel(reqStat);
       
   785 	User::WaitForRequest(reqStat);
       
   786 	test(reqStat==KErrCancel);
       
   787 
       
   788 //	Repeat with a ENotifyFile request
       
   789 	TheFs.NotifyChange(ENotifyFile,reqStat,path);
       
   790 	test(reqStat==KRequestPending);
       
   791 
       
   792 	r=file.Replace(TheFs,path,EFileStream);
       
   793 	test(r==KErrNone);
       
   794 	file.Close();
       
   795 
       
   796 	User::WaitForRequest(reqStat);
       
   797 	test(reqStat==KErrNone);
       
   798 
       
   799 	r=TheFs.Delete(path);
       
   800 	test(r==KErrNone);
       
   801 
       
   802 	TheFs.NotifyChange(ENotifyFile,reqStat,path);
       
   803 	test(reqStat==KRequestPending);
       
   804 //	Now cancel the outstanding request
       
   805 	TheFs.NotifyChangeCancel(reqStat);
       
   806 	User::WaitForRequest(reqStat);
       
   807 	test(reqStat==KErrCancel);
       
   808 
       
   809 //	Repeat with an ENotifyAttributes request
       
   810 	TheFs.NotifyChange(ENotifyAttributes,reqStat,path);
       
   811 	test(reqStat==KRequestPending);
       
   812 
       
   813 	r=file.Replace(TheFs,path,EFileStream);
       
   814 	test(r==KErrNone);
       
   815 	file.Close();
       
   816 
       
   817 	User::WaitForRequest(reqStat);
       
   818 	test(reqStat==KErrNone);	//	Monitoring attributes but informed anyway
       
   819 
       
   820 	r=TheFs.Delete(path);
       
   821 	test(r==KErrNone);
       
   822 
       
   823 	TheFs.NotifyChange(ENotifyAttributes,reqStat,path);
       
   824 	test(reqStat==KRequestPending);
       
   825 //	Now cancel the outstanding request
       
   826 	TheFs.NotifyChangeCancel(reqStat);
       
   827 	User::WaitForRequest(reqStat);
       
   828 	test(reqStat==KErrCancel);
       
   829 
       
   830 //	Repeat with an ENotifyWrite request
       
   831 	TheFs.NotifyChange(ENotifyWrite,reqStat,path);
       
   832 	test(reqStat==KRequestPending);
       
   833 
       
   834 	r=file.Replace(TheFs,path,EFileStream);
       
   835 	test(r==KErrNone);
       
   836 	file.Close();
       
   837 
       
   838 	User::WaitForRequest(reqStat);
       
   839 	test(reqStat==KErrNone);	//	Monitoring file writing but informed anyway
       
   840 
       
   841 	r=TheFs.Delete(path);
       
   842 	test(r==KErrNone);
       
   843 
       
   844 	TheFs.NotifyChange(ENotifyWrite,reqStat,path);
       
   845 	test(reqStat==KRequestPending);
       
   846 //	Now cancel the outstanding request
       
   847 	TheFs.NotifyChangeCancel(reqStat);
       
   848 	User::WaitForRequest(reqStat);
       
   849 	test(reqStat==KErrCancel);
       
   850 
       
   851 //	Repeat with an ENotifyDisk request
       
   852 	TheFs.NotifyChange(ENotifyDisk,reqStat,path);
       
   853 	test(reqStat==KRequestPending);
       
   854 
       
   855 	r=file.Replace(TheFs,path,EFileStream);
       
   856 	test(r==KErrNone);
       
   857 	file.Close();
       
   858 
       
   859 	User::WaitForRequest(reqStat);
       
   860 	test(reqStat==KErrNone);	//	Monitoring disk activity but informed anyway
       
   861 
       
   862 	r=TheFs.Delete(path);
       
   863 	test(r==KErrNone);
       
   864 
       
   865 	TheFs.NotifyChange(ENotifyAttributes,reqStat,path);
       
   866 	test(reqStat==KRequestPending);
       
   867 //	Now cancel the outstanding request
       
   868 	TheFs.NotifyChangeCancel(reqStat);
       
   869 	User::WaitForRequest(reqStat);
       
   870 	test(reqStat==KErrCancel);
       
   871 
       
   872 //	Now do much the same with directory monitoring
       
   873 	path=_L("\\F32-TST\\NOTIFY\\BehindTheCurtain\\");
       
   874 	TheFs.RmDir(path);
       
   875 
       
   876 	TheFs.NotifyChange(ENotifyDir,reqStat,path);
       
   877 	test(reqStat==KRequestPending);
       
   878 
       
   879 	TheFs.MkDir(path);
       
   880 	test(r==KErrNone);
       
   881 
       
   882 	User::WaitForRequest(reqStat);
       
   883 	test(reqStat==KErrNone);
       
   884 
       
   885 	TheFs.RmDir(path);
       
   886 	test(r==KErrNone);
       
   887 
       
   888 	TheFs.NotifyChange(ENotifyDir,reqStat,path);
       
   889 	test(r==KErrNone);
       
   890 	test(reqStat==KRequestPending);
       
   891 
       
   892 //	Now cancel the outstanding request
       
   893 	TheFs.NotifyChangeCancel(reqStat);
       
   894 	User::WaitForRequest(reqStat);
       
   895 	test(reqStat==KErrCancel);
       
   896 
       
   897 	TheFs.NotifyChange(ENotifyDir,reqStat,path);
       
   898 	test(r==KErrNone);
       
   899 	test(reqStat==KRequestPending);
       
   900 
       
   901 //	Get a separate thread to create the directory
       
   902 	RThread thread;
       
   903 	thread.Create(_L("RequestAheadyThready"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest10);
       
   904 	TRequestStatus thrdStat(KRequestPending);
       
   905 	thread.Logon(thrdStat);
       
   906 	thread.Resume();
       
   907 	thread.Close();
       
   908 
       
   909 	User::WaitForRequest(thrdStat);
       
   910 	test(thrdStat==KErrNone);
       
   911 	User::WaitForRequest(reqStat);
       
   912 	test(reqStat==KErrNone);
       
   913 
       
   914 	TheFs.RmDir(path);
       
   915 	test(r==KErrNone);
       
   916 
       
   917 //	Check that notification is not received for a non-existent file if only the previously
       
   918 //	non existent directory that contains it is created
       
   919 	path=_L("\\F32-TST\\NOTIFY\\BehindTheCurtain\\PayNoAttention.man");
       
   920 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
   921 	test(r==KErrNone);
       
   922 	test(reqStat==KRequestPending);
       
   923 
       
   924 	thread.Create(_L("RequestAheadThread"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest10);
       
   925 	thread.Logon(thrdStat);
       
   926 	thread.Resume();
       
   927 	thread.Close();
       
   928 
       
   929 	User::WaitForRequest(thrdStat);
       
   930 	test(thrdStat==KErrNone);
       
   931 	test(reqStat==KRequestPending);
       
   932 
       
   933 //	Now get a thread to create the file
       
   934 	thread.Create(_L("RequestAhead"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest11);
       
   935 	thread.Logon(thrdStat);
       
   936 	thread.Resume();
       
   937 	User::WaitForRequest(thrdStat);
       
   938 	test(thrdStat==KErrNone);
       
   939 	thread.Close();
       
   940 
       
   941 	User::WaitForRequest(reqStat);
       
   942 	test(reqStat==KErrNone);
       
   943 
       
   944 	TheFs.Delete(path);
       
   945 	test(r==KErrNone);
       
   946 
       
   947 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
   948 	test(r==KErrNone);
       
   949 	test(reqStat==KRequestPending);
       
   950 
       
   951 //	Now cancel the outstanding request
       
   952 	TheFs.NotifyChangeCancel(reqStat);
       
   953 	User::WaitForRequest(reqStat);
       
   954 	test(reqStat==KErrCancel);
       
   955 
       
   956 	path=_L("\\F32-TST\\NOTIFY\\BehindTheCurtain\\");
       
   957 	TheFs.RmDir(path);
       
   958 	test(r==KErrNone);
       
   959 	}
       
   960 
       
   961 
       
   962 static void Test8()
       
   963 //
       
   964 // Test extended notification of an entry change
       
   965 //
       
   966 	{
       
   967 //	Test notification of an entry change in directory F32-TST
       
   968 	test.Next(_L("Test notification of an entry change"));
       
   969 	TRequestStatus reqStat(KRequestPending);
       
   970 	TRequestStatus thrdStat(KRequestPending);
       
   971 	TFileName path=(_L("\\F32-TST\\"));
       
   972 
       
   973 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
   974 	test(reqStat==KRequestPending);
       
   975 	RThread thread;
       
   976 	TInt r=thread.Create(_L("MyThread"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest1);
       
   977 	test(r==KErrNone);
       
   978 	thread.Logon(thrdStat);
       
   979 	thread.Resume();
       
   980 	User::WaitForRequest(thrdStat);
       
   981 	test(thrdStat==KErrNone);
       
   982 	User::WaitForRequest(reqStat);
       
   983 	test(reqStat==KErrNone);
       
   984 	thread.Close();
       
   985 
       
   986 //	Repeat the test
       
   987 	test.Next(_L("Repeat Test notification of an entry change"));
       
   988 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
   989 	test(reqStat==KRequestPending);
       
   990 	r=thread.Create(_L("MyThread2"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest1);
       
   991 	test(r==KErrNone);
       
   992 	thread.Logon(thrdStat);
       
   993 	thread.Resume();
       
   994 	User::WaitForRequest(thrdStat);
       
   995 	test(thrdStat==KErrNone);
       
   996 	User::WaitForRequest(reqStat);
       
   997 	test(reqStat==KErrNone);
       
   998 	thread.Close();
       
   999 
       
  1000 //	Test it can be cancelled
       
  1001 	test.Next(_L("Test Notify cancel"));
       
  1002 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1003 	test(reqStat==KRequestPending);
       
  1004 	TheFs.NotifyChangeCancel();
       
  1005 	User::WaitForRequest(reqStat);
       
  1006 	test(reqStat==KErrCancel);
       
  1007 
       
  1008 //	Test it can be notified again
       
  1009 	test.Next(_L("Test notification still works"));
       
  1010 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1011 	test(reqStat==KRequestPending);
       
  1012 	r=thread.Create(_L("MyThread3"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest1);
       
  1013 	test(r==KErrNone);
       
  1014 	thread.Logon(thrdStat);
       
  1015 	thread.Resume();
       
  1016 	User::WaitForRequest(thrdStat);
       
  1017 	test(thrdStat==KErrNone);
       
  1018 	User::WaitForRequest(reqStat);
       
  1019 	test(reqStat==KErrNone);
       
  1020 	thread.Close();
       
  1021 
       
  1022 //	Test notification doesn't occur when a change occurs above the directory monitored
       
  1023 //	(Notification of rename events occurring above the directory which affect the path
       
  1024 //	will occur - this is tested for in Test18())
       
  1025 	test.Next(_L("Test changing above monitored directory"));
       
  1026 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\"));
       
  1027 	test((r==KErrNone)||(r==KErrAlreadyExists));
       
  1028 	path=_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\");
       
  1029 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1030 	test(reqStat==KRequestPending);
       
  1031 	r=thread.Create(_L("MyThread4"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest1);
       
  1032 	test(r==KErrNone);
       
  1033 	thread.Logon(thrdStat);
       
  1034 	thread.Resume();
       
  1035 	User::WaitForRequest(thrdStat);
       
  1036 	test(thrdStat==KErrNone);
       
  1037 	User::After(500000);
       
  1038 	thread.Close();
       
  1039 	test(reqStat==KRequestPending);
       
  1040 	TheFs.NotifyChangeCancel();
       
  1041 	User::WaitForRequest(reqStat);
       
  1042 	test(reqStat==KErrCancel);
       
  1043 
       
  1044 //	Test notification occurs when a change is made to the subdirectory monitored
       
  1045 	test.Next(_L("Create a file in monitored subdirectory"));
       
  1046 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1047 	test(reqStat==KRequestPending);
       
  1048 	r=thread.Create(_L("MyThread5"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest2);
       
  1049 	test(r==KErrNone);
       
  1050 	thread.Logon(thrdStat);
       
  1051 	thread.Resume();
       
  1052 	User::WaitForRequest(thrdStat);
       
  1053 	test(thrdStat==KErrNone);
       
  1054 	User::WaitForRequest(reqStat);
       
  1055 	test(reqStat==KErrNone);
       
  1056 	thread.Close();
       
  1057 
       
  1058 	test.Next(_L("Create a directory in monitored subdirectory"));
       
  1059 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1060 	test(reqStat==KRequestPending);
       
  1061 	r=thread.Create(_L("MyThread6"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest3);
       
  1062 	test(r==KErrNone);
       
  1063 	thread.Logon(thrdStat);
       
  1064 	thread.Resume();
       
  1065 	User::WaitForRequest(thrdStat);
       
  1066 	test(thrdStat==KErrNone);
       
  1067 	User::WaitForRequest(reqStat);
       
  1068 	test(reqStat==KErrNone);
       
  1069 	thread.Close();
       
  1070 
       
  1071 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1072 	test(reqStat==KRequestPending);
       
  1073 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\SCARECROW\\TINMAN\\"));
       
  1074 	test(r==KErrNone);
       
  1075 	User::WaitForRequest(reqStat);
       
  1076 	test(reqStat==KErrNone);
       
  1077 
       
  1078 
       
  1079 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\SCARECROW\\TINMAN\\"));
       
  1080 	test(r==KErrNone);
       
  1081 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\SCARECROW\\"));
       
  1082 	test(r==KErrNone);
       
  1083 
       
  1084 //	Test again that notification doesn't occur above the subdirectory being monitored
       
  1085 	test.Next(_L("Test changing above monitored directory"));
       
  1086 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\"));
       
  1087 	test((r==KErrNone)||(r==KErrAlreadyExists));
       
  1088 	path=_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\");
       
  1089 
       
  1090 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1091 	test(reqStat==KRequestPending);
       
  1092 	r=thread.Create(_L("MyThread7"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest1);
       
  1093 	test(r==KErrNone);
       
  1094 	thread.Logon(thrdStat);
       
  1095 	thread.Resume();
       
  1096 	User::WaitForRequest(thrdStat);
       
  1097 	test(thrdStat==KErrNone);
       
  1098 	User::After(500000);
       
  1099 	thread.Close();
       
  1100 	test(reqStat==KRequestPending);
       
  1101 	TheFs.NotifyChangeCancel();
       
  1102 	User::WaitForRequest(reqStat);
       
  1103 	test(reqStat==KErrCancel);
       
  1104 
       
  1105 //	Test notification occurs when a change is made to the subdirectory monitored
       
  1106 	test.Next(_L("Delete a file in monitored subdirectory"));
       
  1107 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1108 	test(reqStat==KRequestPending);
       
  1109 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"));
       
  1110 	test(r==KErrNone);
       
  1111 	User::WaitForRequest(reqStat);
       
  1112 	test(reqStat==KErrNone);
       
  1113 
       
  1114 	RFile file;
       
  1115 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\WickedWitch.msg"),EFileStream);
       
  1116 	test(r==KErrNone);
       
  1117 	file.Close();
       
  1118 
       
  1119 //	Test notification on a specific file
       
  1120 	test.Next(_L("Monitor changes to a specific file"));
       
  1121 	path+=_L("WickedWitch.msg");
       
  1122 	TheFs.NotifyChange(ENotifyAll,reqStat,path);
       
  1123 	test(reqStat==KRequestPending);
       
  1124 	r=thread.Create(_L("MyThread8"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest8);
       
  1125 	test(r==KErrNone);
       
  1126 	thread.Logon(thrdStat);
       
  1127 	thread.Resume();
       
  1128 	User::WaitForRequest(thrdStat);
       
  1129 	test(thrdStat==KErrNone);
       
  1130 	User::WaitForRequest(reqStat);
       
  1131 	test(reqStat==KErrNone);
       
  1132 	thread.Close();
       
  1133 
       
  1134 //	Test notification does not occur if a change is made above the file
       
  1135 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1136 	test(reqStat==KRequestPending);
       
  1137 	thread.Create(_L("MyThread9"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest2);
       
  1138 	thread.Logon(thrdStat);
       
  1139 	thread.Resume();
       
  1140 	User::WaitForRequest(thrdStat);
       
  1141 	test(thrdStat==KErrNone);
       
  1142 	User::After(500000);
       
  1143 	thread.Close();
       
  1144 	test(reqStat==KRequestPending);
       
  1145 	TheFs.NotifyChangeCancel();
       
  1146 	User::WaitForRequest(reqStat);
       
  1147 	test(reqStat==KErrCancel);
       
  1148 
       
  1149 //	Test notification occurs when a change is made to the file
       
  1150 	test.Next(_L("Delete monitored file"));
       
  1151 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1152 	test(reqStat==KRequestPending);
       
  1153 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\WickedWitch.Msg"));
       
  1154 	test(r==KErrNone);
       
  1155 	User::WaitForRequest(reqStat);
       
  1156 	test(reqStat==KErrNone);
       
  1157 
       
  1158 //	Test notification request is now submitted on the non existent path successfully
       
  1159 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1160 	test(reqStat==KRequestPending);
       
  1161 	TheFs.NotifyChangeCancel(reqStat);
       
  1162 	User::WaitForRequest(reqStat);
       
  1163 	test(reqStat==KErrCancel);
       
  1164 
       
  1165 	path=_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.Doc");
       
  1166 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1167 	test(reqStat==KRequestPending);
       
  1168 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.Doc"));
       
  1169 	test(r==KErrNone);
       
  1170 	User::WaitForRequest(reqStat);
       
  1171 	test(reqStat==KErrNone);
       
  1172 
       
  1173 	path=_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\");
       
  1174 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1175 	test(reqStat==KRequestPending);
       
  1176 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\"));
       
  1177 	test(r==KErrNone);
       
  1178 	User::WaitForRequest(reqStat);
       
  1179 	test(reqStat==KErrNone);
       
  1180 
       
  1181 //	Submit a request for a path which does not yet exist
       
  1182 	path=_L("\\F32-TST\\NOTIFY\\GOOD_WITCH\\");
       
  1183 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1184 	test(reqStat==KRequestPending);
       
  1185 //	Now create the directory we are waiting on
       
  1186 	r=TheFs.MkDir(path);
       
  1187 	test(r==KErrNone);
       
  1188 //	Make sure the notification has now been received
       
  1189 	User::WaitForRequest(reqStat);
       
  1190 	test(reqStat==KErrNone);
       
  1191 
       
  1192 //	Submit a request for a file which does not yet exist
       
  1193 	path=_L("\\F32-TST\\NOTIFY\\GOOD_WITCH\\Red-Shoes.red");
       
  1194 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1195 	test(reqStat==KRequestPending);
       
  1196 //	Now create the file we are waiting on
       
  1197 	r=file.Replace(TheFs,path,EFileStream);
       
  1198 	test(r==KErrNone);
       
  1199 	file.Close();
       
  1200 //	Make sure the notification has now been received
       
  1201 	User::WaitForRequest(reqStat);
       
  1202 	test(reqStat==KErrNone);
       
  1203 //	Submit another notification request and delete the file
       
  1204 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1205 	test(reqStat==KRequestPending);
       
  1206 	r=TheFs.Delete(path);
       
  1207 	test(r==KErrNone);
       
  1208 	User::WaitForRequest(reqStat);
       
  1209 	test(reqStat==KErrNone);
       
  1210 	path=_L("\\F32-TST\\NOTIFY\\GOOD_WITCH\\");
       
  1211 	TheFs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1212 	test(reqStat==KRequestPending);
       
  1213 	r=TheFs.RmDir(path);
       
  1214 	test(r==KErrNone);
       
  1215 	User::WaitForRequest(reqStat);
       
  1216 	test(reqStat==KErrNone);
       
  1217 	// test passing in an empty string
       
  1218 	TheFs.NotifyChange(ENotifyEntry,reqStat,_L(""));
       
  1219 	User::WaitForRequest(reqStat);
       
  1220 	test(reqStat==KErrArgument);
       
  1221 	}
       
  1222 
       
  1223 static void Test9()
       
  1224 //
       
  1225 // Test notify for multiple clients
       
  1226 //
       
  1227 	{
       
  1228 
       
  1229 	test.Next(_L("Test notification of multiple clients"));
       
  1230 
       
  1231 //	Create five sessions monitoring various levels of a directory tree
       
  1232 
       
  1233 	TInt r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\ANIMAL\\"));
       
  1234 	test((r==KErrNone)||(r==KErrAlreadyExists));
       
  1235 	RFile file;
       
  1236 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\ANIMAL\\cat.txt"),EFileStream);
       
  1237 	test(r==KErrNone);
       
  1238 	file.Close();
       
  1239 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\ANIMAL\\dog.txt"),EFileStream);
       
  1240 	test(r==KErrNone);
       
  1241 	file.Close();
       
  1242 
       
  1243 	TFileName path1=_L("\\F32-TST\\");
       
  1244 	TFileName path2=_L("\\F32-TST\\NOTIFY\\");
       
  1245 	TFileName path3=_L("\\F32-TST\\NOTIFY\\ANIMAL\\");
       
  1246 	TFileName path4=_L("\\F32-TST\\NOTIFY\\ANIMAL\\cat.txt");
       
  1247 	TFileName path5=_L("\\F32-TST\\NOTIFY\\ANIMAL\\dog.txt");
       
  1248 	TFileName path6=_L("?:\\F32-TST\\");
       
  1249 
       
  1250 	TRequestStatus reqStat1(KRequestPending);
       
  1251 	RFs fs1;
       
  1252 	r=fs1.Connect();
       
  1253 	test(r==KErrNone);
       
  1254 	r=fs1.SetSessionPath(gSessionPath);
       
  1255 	test(r==KErrNone);
       
  1256 	fs1.NotifyChange(ENotifyEntry,reqStat1,path1);
       
  1257 
       
  1258 	TRequestStatus reqStat2(KRequestPending);
       
  1259 	RFs fs2;
       
  1260 	r=fs2.Connect();
       
  1261 	test(r==KErrNone);
       
  1262 	r=fs2.SetSessionPath(gSessionPath);
       
  1263 	test(r==KErrNone);
       
  1264 	fs2.NotifyChange(ENotifyEntry,reqStat2,path2);
       
  1265 
       
  1266 	TRequestStatus reqStat3(KRequestPending);
       
  1267 	RFs fs3;
       
  1268 	r=fs3.Connect();
       
  1269 	test(r==KErrNone);
       
  1270 	r=fs3.SetSessionPath(gSessionPath);
       
  1271 	test(r==KErrNone);
       
  1272 	fs3.NotifyChange(ENotifyEntry,reqStat3,path3);
       
  1273 
       
  1274 	TRequestStatus reqStat4(KRequestPending);
       
  1275 	RFs fs4;
       
  1276 	r=fs4.Connect();
       
  1277 	test(r==KErrNone);
       
  1278 	r=fs4.SetSessionPath(gSessionPath);
       
  1279 	test(r==KErrNone);
       
  1280 	fs4.NotifyChange(ENotifyEntry,reqStat4,path4);
       
  1281 
       
  1282 	TRequestStatus reqStat5(KRequestPending);
       
  1283 	RFs fs5;
       
  1284 	r=fs5.Connect();
       
  1285 	test(r==KErrNone);
       
  1286 	r=fs5.SetSessionPath(gSessionPath);
       
  1287 	test(r==KErrNone);
       
  1288 	fs5.NotifyChange(ENotifyEntry,reqStat5,path5);
       
  1289 
       
  1290 	TRequestStatus reqStat6(KRequestPending);
       
  1291 	RFs fs6;
       
  1292 	r=fs6.Connect();
       
  1293 	test(r==KErrNone);
       
  1294 	r=fs6.SetSessionPath(gSessionPath);
       
  1295 	test(r==KErrNone);
       
  1296 	fs6.NotifyChange(ENotifyEntry,reqStat6,path6);
       
  1297 
       
  1298 	test(reqStat1==KRequestPending);
       
  1299 	test(reqStat2==KRequestPending);
       
  1300 	test(reqStat3==KRequestPending);
       
  1301 	test(reqStat4==KRequestPending);
       
  1302 	test(reqStat5==KRequestPending);
       
  1303 	test(reqStat6==KRequestPending);
       
  1304 
       
  1305 //	Make a change a the top level and check that only the session monitoring
       
  1306 //	that level is notified
       
  1307 	test.Next(_L("Test only client monitoring top level is notified"));
       
  1308 	r=file.Replace(TheFs,_L("\\F32-TST\\NewFile.txt"),EFileStream);
       
  1309 	test(r==KErrNone);
       
  1310 	file.Close();
       
  1311 	User::WaitForRequest(reqStat1);
       
  1312 	test(reqStat1==KErrNone);
       
  1313 	test(reqStat2==KRequestPending);
       
  1314 	test(reqStat3==KRequestPending);
       
  1315 	test(reqStat4==KRequestPending);
       
  1316 	test(reqStat5==KRequestPending);
       
  1317 	User::WaitForRequest(reqStat6);
       
  1318 	test(reqStat6==KErrNone);
       
  1319 
       
  1320 	r=TheFs.Delete(_L("\\F32-TST\\NewFile.txt"));
       
  1321 	test(r==KErrNone);
       
  1322 
       
  1323 //	Renew the notify request at the top level and make a change one step lower
       
  1324 	fs1.NotifyChange(ENotifyEntry,reqStat1,path1);
       
  1325 	fs6.NotifyChange(ENotifyEntry,reqStat6,path6);
       
  1326 	test(reqStat1==KRequestPending);
       
  1327 	test(reqStat6==KRequestPending);
       
  1328 
       
  1329 	test.Next(_L("Test clients monitoring levels 1 and 2 are notified"));
       
  1330 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileStream);
       
  1331 	test(r==KErrNone);
       
  1332 	file.Close();
       
  1333 
       
  1334 	User::WaitForRequest(reqStat1);
       
  1335 	User::WaitForRequest(reqStat2);
       
  1336 	test(reqStat1==KErrNone);
       
  1337 	test(reqStat2==KErrNone);
       
  1338 	test(reqStat3==KRequestPending);
       
  1339 	test(reqStat4==KRequestPending);
       
  1340 	test(reqStat5==KRequestPending);
       
  1341 	User::WaitForRequest(reqStat6);
       
  1342 	test(reqStat6==KErrNone);
       
  1343 
       
  1344 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\NewFile.txt"));
       
  1345 	test(r==KErrNone);
       
  1346 
       
  1347 //	Renew the notify request at the top and second levels and make a change
       
  1348 //	one step lower still
       
  1349 	fs1.NotifyChange(ENotifyEntry,reqStat1,path1);
       
  1350 	fs2.NotifyChange(ENotifyEntry,reqStat2,path2);
       
  1351 	fs6.NotifyChange(ENotifyEntry,reqStat6,path6);
       
  1352 	test(reqStat1==KRequestPending);
       
  1353 	test(reqStat2==KRequestPending);
       
  1354 	test(reqStat6==KRequestPending);
       
  1355 
       
  1356 	test.Next(_L("Test clients monitoring levels 1,2 and 3 are notified"));
       
  1357 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\ANIMAL\\NewFile.txt"),EFileStream);
       
  1358 	test(r==KErrNone);
       
  1359 	file.Close();
       
  1360 
       
  1361 	User::WaitForRequest(reqStat1);
       
  1362 	User::WaitForRequest(reqStat2);
       
  1363 	User::WaitForRequest(reqStat3);
       
  1364 	test(reqStat1==KErrNone);
       
  1365 	test(reqStat2==KErrNone);
       
  1366 	test(reqStat3==KErrNone);
       
  1367 	test(reqStat4==KRequestPending);
       
  1368 	test(reqStat5==KRequestPending);
       
  1369 	User::WaitForRequest(reqStat6);
       
  1370 	test(reqStat6==KErrNone);
       
  1371 
       
  1372 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\ANIMAL\\NewFile.txt"));
       
  1373 	test(r==KErrNone);
       
  1374 
       
  1375 //	Renew the notify request at the top, second and third levels and make a change
       
  1376 //	one step lower still
       
  1377 	fs1.NotifyChange(ENotifyEntry,reqStat1,path1);
       
  1378 	fs2.NotifyChange(ENotifyEntry,reqStat2,path2);
       
  1379 	fs3.NotifyChange(ENotifyEntry,reqStat3,path3);
       
  1380 	fs6.NotifyChange(ENotifyEntry,reqStat6,path6);
       
  1381 	test(reqStat1==KRequestPending);
       
  1382 	test(reqStat2==KRequestPending);
       
  1383 	test(reqStat3==KRequestPending);
       
  1384 	test(reqStat6==KRequestPending);
       
  1385 
       
  1386 	test.Next(_L("Test clients monitoring levels 1 - 4 are notified"));
       
  1387 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\ANIMAL\\cat.txt"));
       
  1388 	test(r==KErrNone);
       
  1389 	User::WaitForRequest(reqStat1);
       
  1390 	User::WaitForRequest(reqStat2);
       
  1391 	User::WaitForRequest(reqStat3);
       
  1392 	User::WaitForRequest(reqStat4);
       
  1393 	test(reqStat1==KErrNone);
       
  1394 	test(reqStat2==KErrNone);
       
  1395 	test(reqStat3==KErrNone);
       
  1396 	test(reqStat4==KErrNone);
       
  1397 	test(reqStat5==KRequestPending);
       
  1398 	User::WaitForRequest(reqStat6);
       
  1399 	test(reqStat6==KErrNone);
       
  1400 
       
  1401 //	Renew the notify request at the top, second and third levels and on the file deleted above
       
  1402 //	which will be successful, but will not complete (for obvious reasons)
       
  1403 
       
  1404 //	Make a change one step lower still
       
  1405 	fs1.NotifyChange(ENotifyEntry,reqStat1,path1);
       
  1406 	fs2.NotifyChange(ENotifyEntry,reqStat2,path2);
       
  1407 	fs3.NotifyChange(ENotifyEntry,reqStat3,path3);
       
  1408 	fs6.NotifyChange(ENotifyEntry,reqStat6,path6);
       
  1409 	fs4.NotifyChange(ENotifyEntry,reqStat4,path4);
       
  1410 	test(reqStat1==KRequestPending);
       
  1411 	test(reqStat2==KRequestPending);
       
  1412 	test(reqStat3==KRequestPending);
       
  1413 	test(reqStat4==KRequestPending);
       
  1414 	test(reqStat6==KRequestPending);
       
  1415 
       
  1416 	test.Next(_L("Test clients monitoring levels 1 - 3 and 5 are notified"));
       
  1417 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\ANIMAL\\dog.txt"));
       
  1418 	test(r==KErrNone);
       
  1419 	User::WaitForRequest(reqStat1);
       
  1420 	User::WaitForRequest(reqStat2);
       
  1421 	User::WaitForRequest(reqStat3);
       
  1422 //	Don't wait for reqStat4
       
  1423 	User::WaitForRequest(reqStat5);
       
  1424 	User::WaitForRequest(reqStat6);
       
  1425 	test(reqStat1==KErrNone);
       
  1426 	test(reqStat2==KErrNone);
       
  1427 	test(reqStat3==KErrNone);
       
  1428 	test(reqStat4==KRequestPending);	//	File does not exist
       
  1429 	test(reqStat5==KErrNone);
       
  1430 	test(reqStat6==KErrNone);
       
  1431 
       
  1432 	fs4.NotifyChangeCancel(reqStat4);
       
  1433 	User::WaitForRequest(reqStat4);
       
  1434 	test(reqStat4==KErrCancel);
       
  1435 //	Renew the notify request at the top, second and third levels and attempt to renew
       
  1436 //	the request on the files deleted above (which will fail).
       
  1437 
       
  1438 	test.Next(_L("Test clients monitoring levels 1 - 3 are notified"));
       
  1439 	fs1.NotifyChange(ENotifyEntry,reqStat1,path1);
       
  1440 	fs2.NotifyChange(ENotifyEntry,reqStat2,path2);
       
  1441 	fs3.NotifyChange(ENotifyEntry,reqStat3,path3);
       
  1442 	fs4.NotifyChange(ENotifyEntry,reqStat4,path4);
       
  1443 	fs6.NotifyChange(ENotifyEntry,reqStat6,path6);
       
  1444 	fs5.NotifyChange(ENotifyEntry,reqStat5,path5);
       
  1445 	test(reqStat1==KRequestPending);
       
  1446 	test(reqStat2==KRequestPending);
       
  1447 	test(reqStat3==KRequestPending);
       
  1448 	test(reqStat4==KRequestPending);
       
  1449 	test(reqStat5==KRequestPending);
       
  1450 	test(reqStat6==KRequestPending);
       
  1451 
       
  1452 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\ANIMAL\\"));
       
  1453 	test(r==KErrNone);
       
  1454 	User::WaitForRequest(reqStat1);
       
  1455 	User::WaitForRequest(reqStat2);
       
  1456 	User::WaitForRequest(reqStat3);
       
  1457 	test(reqStat1==KErrNone);
       
  1458 	test(reqStat2==KErrNone);
       
  1459 	test(reqStat3==KErrNone);
       
  1460 	test(reqStat4==KRequestPending);
       
  1461 	test(reqStat5==KRequestPending);
       
  1462 	User::WaitForRequest(reqStat6);
       
  1463 	test(reqStat6==KErrNone);
       
  1464 
       
  1465 //	Renew the notify request at the top and second levels on the third level
       
  1466 //	which was removed - it'll succeed but won't complete.
       
  1467 
       
  1468 	test.Next(_L("Test clients monitoring levels 1 and 2 are notified"));
       
  1469 	test.Next(_L("Test clients' attempts to monitor levels 3-5 fail"));
       
  1470 	fs1.NotifyChange(ENotifyEntry,reqStat1,path1);
       
  1471 	fs2.NotifyChange(ENotifyEntry,reqStat2,path2);
       
  1472 	fs3.NotifyChange(ENotifyEntry,reqStat3,path3);
       
  1473 	fs6.NotifyChange(ENotifyEntry,reqStat6,path6);
       
  1474 
       
  1475 	test(reqStat1==KRequestPending);
       
  1476 	test(reqStat2==KRequestPending);
       
  1477 	test(reqStat3==KRequestPending);
       
  1478 	test(reqStat4==KRequestPending);
       
  1479 	test(reqStat5==KRequestPending);
       
  1480 	test(reqStat6==KRequestPending);
       
  1481 
       
  1482 	fs1.NotifyChangeCancel();
       
  1483 	fs2.NotifyChangeCancel();
       
  1484 
       
  1485 	fs1.Close();
       
  1486 	fs2.Close();
       
  1487 //	Close the other sessions with requests outstanding to test that there's no evilness
       
  1488 	fs3.Close();
       
  1489 	fs4.Close();
       
  1490 	fs5.Close();
       
  1491 	fs6.Close();
       
  1492 
       
  1493 	User::WaitForRequest(reqStat1);
       
  1494 	User::WaitForRequest(reqStat2);
       
  1495 	// Closing file server sessions doesn't seem to complete notifications, is this a bug?
       
  1496 //	User::WaitForRequest(reqStat3);
       
  1497 //	User::WaitForRequest(reqStat4);
       
  1498 //	User::WaitForRequest(reqStat5);
       
  1499 //	User::WaitForRequest(reqStat6);
       
  1500 	}
       
  1501 
       
  1502 static void Test10()
       
  1503 //
       
  1504 // Test notify cancel
       
  1505 //
       
  1506 	{
       
  1507 
       
  1508 	test.Next(_L("Cancel notification request using simple function"));
       
  1509 	TFileName path=_L("\\F32-TST\\NOTIFY\\");
       
  1510 	RFs fs1;
       
  1511 	TInt r=fs1.Connect();
       
  1512 	test(r==KErrNone);
       
  1513 	r=fs1.SetSessionPath(gSessionPath);
       
  1514 	test(r==KErrNone);
       
  1515 
       
  1516 	TRequestStatus status1;
       
  1517 	TRequestStatus status2;
       
  1518 	TRequestStatus status3;
       
  1519 	TRequestStatus status4;
       
  1520 	TRequestStatus status5;
       
  1521 
       
  1522 	fs1.NotifyChange(ENotifyAll,status1,path);
       
  1523 	fs1.NotifyChange(ENotifyAll,status2,path);
       
  1524 	fs1.NotifyChange(ENotifyAll,status3,path);
       
  1525 	fs1.NotifyChange(ENotifyAll,status4,path);
       
  1526 	fs1.NotifyChange(ENotifyAll,status5,path);
       
  1527 	test(status1==KRequestPending);
       
  1528 	test(status2==KRequestPending);
       
  1529 	test(status3==KRequestPending);
       
  1530 	test(status4==KRequestPending);
       
  1531 	test(status5==KRequestPending);
       
  1532 
       
  1533 	test.Next(_L("RFs::NotifyCancel()"));
       
  1534 //	Test that one call to RFs::NotifyCancel() cancels all outstanding requests
       
  1535 	fs1.NotifyChangeCancel();
       
  1536 	User::WaitForRequest(status1);
       
  1537 	test(status1==KErrCancel);
       
  1538 	User::WaitForRequest(status2);
       
  1539 	test(status2==KErrCancel);
       
  1540 	User::WaitForRequest(status3);
       
  1541 	test(status3==KErrCancel);
       
  1542 	User::WaitForRequest(status4);
       
  1543 	test(status4==KErrCancel);
       
  1544 	User::WaitForRequest(status5);
       
  1545 	test(status5==KErrCancel);
       
  1546 //	Call the cancel function again to check no further action
       
  1547 	fs1.NotifyChangeCancel();
       
  1548 
       
  1549 //	Test overloaded function to cancel a single request
       
  1550 	test.Next(_L("Cancel notification request using function overload"));
       
  1551 	fs1.NotifyChange(ENotifyAll,status1,path);
       
  1552 	fs1.NotifyChange(ENotifyAll,status2,path);
       
  1553 	fs1.NotifyChange(ENotifyAll,status3,path);
       
  1554 	fs1.NotifyChange(ENotifyAll,status4,path);
       
  1555 	fs1.NotifyChange(ENotifyAll,status5,path);
       
  1556 	test(status1==KRequestPending);
       
  1557 	test(status2==KRequestPending);
       
  1558 	test(status3==KRequestPending);
       
  1559 	test(status4==KRequestPending);
       
  1560 	test(status5==KRequestPending);
       
  1561 
       
  1562 //	Cancel the outstanding request with status5
       
  1563 	test.Next(_L("RFs::NotifyCancel()"));
       
  1564 	fs1.NotifyChangeCancel(status5);
       
  1565 	User::WaitForRequest(status5);
       
  1566 	test(status1==KRequestPending);
       
  1567 	test(status2==KRequestPending);
       
  1568 	test(status3==KRequestPending);
       
  1569 	test(status4==KRequestPending);
       
  1570 	test(status5==KErrCancel);
       
  1571 
       
  1572 	r=TheFs.MkDir(_L("\\F32-TST\\TROPICANA\\"));
       
  1573 	test(r==KErrNone);
       
  1574 	test(status1==KRequestPending);
       
  1575 	test(status2==KRequestPending);
       
  1576 	test(status3==KRequestPending);
       
  1577 	test(status4==KRequestPending);
       
  1578 
       
  1579 	fs1.NotifyChangeCancel(status2);
       
  1580 	User::WaitForRequest(status2);
       
  1581 
       
  1582 	test(status1==KRequestPending);
       
  1583 	test(status2==KErrCancel);
       
  1584 	test(status3==KRequestPending);
       
  1585 	test(status4==KRequestPending);
       
  1586 
       
  1587 	r=TheFs.RmDir(_L("\\F32-TST\\TROPICANA\\"));
       
  1588 	test(r==KErrNone);
       
  1589 	test(status1==KRequestPending);
       
  1590 	test(status3==KRequestPending);
       
  1591 	test(status4==KRequestPending);
       
  1592 
       
  1593 	fs1.NotifyChangeCancel(status4);
       
  1594 	User::WaitForRequest(status4);
       
  1595 	test(status1==KRequestPending);
       
  1596 	test(status3==KRequestPending);
       
  1597 	test(status4==KErrCancel);
       
  1598 
       
  1599 	fs1.NotifyChangeCancel(status4);	//	Test no side effects on trying to cancel a request
       
  1600 	test(status4==KErrCancel);			//	that has already been cancelled
       
  1601 
       
  1602 	fs1.NotifyChangeCancel(status1);
       
  1603 	User::WaitForRequest(status1);
       
  1604 	test(status1==KErrCancel);
       
  1605 	test(status3==KRequestPending);
       
  1606 	fs1.NotifyChangeCancel(status1);	//	Test no side effects on trying to cancel a request
       
  1607 	test(status1==KErrCancel);			//	that has already been cancelled
       
  1608 
       
  1609 	fs1.NotifyChangeCancel(status3);
       
  1610 	User::WaitForRequest(status3);
       
  1611 	test(status3==KErrCancel);
       
  1612 
       
  1613 	fs1.Close();
       
  1614 	}
       
  1615 
       
  1616 static void Test11()
       
  1617 //
       
  1618 // Test notify client death
       
  1619 //
       
  1620 	{
       
  1621 
       
  1622 	test.Next(_L("Kill client while it is monitoring changes to a directory"));
       
  1623 //	Call CreateLocal to create RSemaphore gSleepThread which is local to this process
       
  1624 	TInt r=gSleepThread.CreateLocal(0);
       
  1625 	test(r==KErrNone);
       
  1626 
       
  1627 	RThread clientThread;
       
  1628 	r=clientThread.Create(_L("ClientThread"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest9);
       
  1629 	test(r==KErrNone);
       
  1630 	clientThread.Resume();
       
  1631 	gSleepThread.Wait();	//	Wait for gSleepThread to be signalled
       
  1632 							//	Client thread is waiting for notification of changes
       
  1633 							//	to directory \\F32-TST\\NOTIFY
       
  1634 
       
  1635 	TBool jit = User::JustInTime();
       
  1636 	User::SetJustInTime(EFalse);
       
  1637 	clientThread.Panic(_L("Test client thread panic"),KErrGeneral);	//	Panic client
       
  1638 	User::SetJustInTime(jit);
       
  1639 
       
  1640 	clientThread.Close();
       
  1641 
       
  1642 //	Make a change and check there's no disaster
       
  1643 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\"));
       
  1644 	test(r==KErrNone || r==KErrAlreadyExists);
       
  1645 	MakeFile(_L("\\F32-TST\\NOTIFY\\NewFile.Txt"));
       
  1646 	User::After(1000);
       
  1647 	}
       
  1648 
       
  1649 
       
  1650 static void Test12()
       
  1651 //
       
  1652 // Test reads and writes do not cause notification under ENotifyEntry
       
  1653 // Test reads and writes do cause notification under ENotifyAll
       
  1654 //
       
  1655 	{
       
  1656 
       
  1657 	test.Next(_L("Test reads and writes do not cause notification under ENotifyEntry"));
       
  1658 
       
  1659 	RFile file;
       
  1660 	TInt r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\kangaroo.txt"),EFileRead|EFileWrite);
       
  1661 	test(r==KErrNone);
       
  1662 	file.Close();
       
  1663 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\koala.txt"),EFileRead|EFileWrite);
       
  1664 	test(r==KErrNone);
       
  1665 	file.Close();
       
  1666 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\dingo.txt"),EFileRead|EFileWrite);
       
  1667 	test(r==KErrNone);
       
  1668 	file.Close();
       
  1669 
       
  1670 	TFileName path=_L("\\F32-TST\\NOTIFY\\");
       
  1671 	TRequestStatus reqStat1(KRequestPending);
       
  1672 	RFs fs1;
       
  1673 	r=fs1.Connect();
       
  1674 	test(r==KErrNone);
       
  1675 	r=fs1.SetSessionPath(gSessionPath);
       
  1676 	test(r==KErrNone);
       
  1677 	fs1.NotifyChange(ENotifyEntry,reqStat1,path);
       
  1678 
       
  1679 	TRequestStatus reqStat2(KRequestPending);
       
  1680 	RFs fs2;
       
  1681 	r=fs2.Connect();
       
  1682 	test(r==KErrNone);
       
  1683 	r=fs2.SetSessionPath(gSessionPath);
       
  1684 	test(r==KErrNone);
       
  1685 	fs2.NotifyChange(ENotifyEntry,reqStat2,path);
       
  1686 
       
  1687 	TRequestStatus reqStat3(KRequestPending);
       
  1688 	RFs fs3;
       
  1689 	r=fs3.Connect();
       
  1690 	test(r==KErrNone);
       
  1691 	r=fs3.SetSessionPath(gSessionPath);
       
  1692 	test(r==KErrNone);
       
  1693 	fs3.NotifyChange(ENotifyEntry,reqStat3,path);
       
  1694 
       
  1695 	test(reqStat1==KRequestPending);
       
  1696 	test(reqStat2==KRequestPending);
       
  1697 	test(reqStat3==KRequestPending);
       
  1698 
       
  1699 	r=gSleepThread.CreateLocal(0);
       
  1700 	test(r==KErrNone);
       
  1701 	RThread thread1;
       
  1702 	r=thread1.Create(_L("TestThread1"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest5);
       
  1703 	test(r==KErrNone);
       
  1704 	thread1.Resume();
       
  1705 	gSleepThread.Wait();
       
  1706 
       
  1707 	test(reqStat1==KRequestPending);
       
  1708 	test(reqStat2==KRequestPending);
       
  1709 	test(reqStat3==KRequestPending);
       
  1710 
       
  1711 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\kangaroo.txt"));
       
  1712 	test(r==KErrNone);
       
  1713 	User::WaitForRequest(reqStat1);
       
  1714 	User::WaitForRequest(reqStat2);
       
  1715 	User::WaitForRequest(reqStat3);
       
  1716 	test(reqStat1==KErrNone);	//	All three notifications occur because they
       
  1717 	test(reqStat2==KErrNone);	//	are all monitoring the top level directory
       
  1718 	test(reqStat3==KErrNone);	//	Later, we'll test monitoring individual files...
       
  1719 
       
  1720 	gSleepThread.Close();
       
  1721 	thread1.Close();
       
  1722 
       
  1723 	test.Next(_L("Test reads and writes do cause notification under ENotifyAll"));
       
  1724 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\kangaroo.txt"),EFileRead|EFileWrite);
       
  1725 	test(r==KErrNone);
       
  1726 	file.Close();
       
  1727 
       
  1728 	fs1.NotifyChange(ENotifyAll,reqStat1,path);
       
  1729 	fs2.NotifyChange(ENotifyAll,reqStat2,path);
       
  1730 	fs3.NotifyChange(ENotifyAll,reqStat3,path);
       
  1731 
       
  1732 	test(reqStat1==KRequestPending);
       
  1733 	test(reqStat2==KRequestPending);
       
  1734 	test(reqStat3==KRequestPending);
       
  1735 
       
  1736 	r=gSleepThread.CreateLocal(0);
       
  1737 	test(r==KErrNone);
       
  1738 	RThread thread2;
       
  1739 	r=thread2.Create(_L("TestThread2"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest5);
       
  1740 	test(r==KErrNone);
       
  1741 	thread2.Resume();
       
  1742 	gSleepThread.Wait();
       
  1743 
       
  1744 	User::WaitForRequest(reqStat1);
       
  1745 	User::WaitForRequest(reqStat2);
       
  1746 	User::WaitForRequest(reqStat3);
       
  1747 	test(reqStat1==KErrNone);
       
  1748 	test(reqStat2==KErrNone);
       
  1749 	test(reqStat3==KErrNone);
       
  1750 
       
  1751 	gSleepThread.Close();
       
  1752 	thread2.Close();
       
  1753 
       
  1754 	test.Next(_L("Monitor reads and writes on specific files with either TNotifyType"));
       
  1755 	TFileName path1=path;
       
  1756 	TFileName path2=path;
       
  1757 	TFileName path3=path;
       
  1758 	path1+=_L("kangaroo.txt");
       
  1759 	path2+=_L("koala.txt");
       
  1760 	path3+=_L("dingo.txt");
       
  1761 
       
  1762 	fs1.NotifyChange(ENotifyAll,reqStat1,path1);
       
  1763 	fs2.NotifyChange(ENotifyEntry,reqStat2,path2);
       
  1764 	fs3.NotifyChange(ENotifyAll,reqStat3,path3);
       
  1765 
       
  1766 	test(reqStat1==KRequestPending);
       
  1767 	test(reqStat2==KRequestPending);
       
  1768 	test(reqStat3==KRequestPending);
       
  1769 
       
  1770 	r=gSleepThread.CreateLocal(0);
       
  1771 	test(r==KErrNone);
       
  1772 	RThread thread3;
       
  1773 	r=thread3.Create(_L("TestThread3"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest5);
       
  1774 	test(r==KErrNone);
       
  1775 	thread3.Resume();
       
  1776 	gSleepThread.Wait();
       
  1777 
       
  1778 	User::WaitForRequest(reqStat1);
       
  1779 	test(reqStat1==KErrNone);
       
  1780 	test(reqStat2==KRequestPending);	//	Monitoring with ENotifyEntry
       
  1781 	User::WaitForRequest(reqStat3);
       
  1782 	test(reqStat3==KErrNone);
       
  1783 
       
  1784 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\koala.txt"));
       
  1785 	test(r==KErrNone);
       
  1786 	User::WaitForRequest(reqStat2);
       
  1787 	test(reqStat2==KErrNone);
       
  1788 
       
  1789 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\kangaroo.txt"));
       
  1790 	test(r==KErrNone);
       
  1791 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\dingo.txt"));
       
  1792 	test(r==KErrNone);
       
  1793 
       
  1794 	gSleepThread.Close();
       
  1795 	thread3.Close();
       
  1796 	fs1.Close();
       
  1797 	fs2.Close();
       
  1798 	fs3.Close();
       
  1799 	}
       
  1800 
       
  1801 
       
  1802 static void Test13()
       
  1803 //
       
  1804 //	Test file notification
       
  1805 //
       
  1806 	{
       
  1807 	RFs fs;	//	Session to be notified of any changes
       
  1808 	TInt r=fs.Connect();
       
  1809 	test(r==KErrNone);
       
  1810 	r=fs.SetSessionPath(gSessionPath);
       
  1811 	test(r==KErrNone);
       
  1812 
       
  1813 
       
  1814 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\"));
       
  1815 	test(r==KErrNone||r==KErrAlreadyExists);
       
  1816 
       
  1817 	RFile file;
       
  1818 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\WickedWitch.msg"),EFileStream);
       
  1819 	test(r==KErrNone||KErrAlreadyExists);
       
  1820 	file.Close();
       
  1821 
       
  1822 //	Test notification on a specific file
       
  1823 	test.Next(_L("Monitor changes to a specific file"));
       
  1824 	TFileName path=_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\WickedWitch.msg");
       
  1825 	TRequestStatus reqStat(KRequestPending);
       
  1826 	TRequestStatus thrdStat(KRequestPending);
       
  1827 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1828 	test(reqStat==KRequestPending);
       
  1829 	RThread thread;
       
  1830 	r=thread.Create(_L("MyThread7"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest8);
       
  1831 	test(r==KErrNone);
       
  1832 	thread.Logon(thrdStat);
       
  1833 	thread.Resume();
       
  1834 	User::WaitForRequest(thrdStat);
       
  1835 	test(thrdStat==KErrNone);
       
  1836 	User::WaitForRequest(reqStat);
       
  1837 	test(reqStat==KErrNone);
       
  1838 	thread.Close();
       
  1839 //	Test notification does not occur if a change is made above the file
       
  1840 	fs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1841 	test(reqStat==KRequestPending);
       
  1842 	r=thread.Create(_L("MyThread8"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest1);
       
  1843 	test(r==KErrNone);
       
  1844 	thread.Logon(thrdStat);
       
  1845 	thread.Resume();
       
  1846 	User::WaitForRequest(thrdStat);
       
  1847 	test(thrdStat==KErrNone);
       
  1848 	User::After(500000);
       
  1849 	thread.Close();
       
  1850 	test(reqStat==KRequestPending);
       
  1851 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\NEWFILE.TXT"));
       
  1852 	test(r==KErrNone);
       
  1853 
       
  1854 //	Test notification does not occur if a change is made to another file
       
  1855 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Lion.log"),EFileStream);
       
  1856 	test(r==KErrNone);
       
  1857 	test(reqStat==KRequestPending);
       
  1858 	file.Close();
       
  1859 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Lion.log"));
       
  1860 	test(r==KErrNone);
       
  1861 	test(reqStat==KRequestPending);
       
  1862 
       
  1863 
       
  1864 //	Test notification occurs when a change is made to the file
       
  1865 	test.Next(_L("Delete monitored file"));
       
  1866 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\WickedWitch.Msg"));
       
  1867 	test(r==KErrNone);
       
  1868 	User::WaitForRequest(reqStat);
       
  1869 	test(reqStat==KErrNone);
       
  1870 
       
  1871 	fs.Close();
       
  1872 	}
       
  1873 
       
  1874 static void Test14()
       
  1875 
       
  1876 	{
       
  1877 //
       
  1878 //	Test notification request succeeds with all RFile and RFs operations which result in
       
  1879 //	notifications
       
  1880 //
       
  1881 	RFs fs;
       
  1882 	TInt r=fs.Connect();	//	Session to be notified of any changes
       
  1883 	test(r==KErrNone);
       
  1884 	r=fs.SetSessionPath(gSessionPath);
       
  1885 	test(r==KErrNone);
       
  1886 
       
  1887 //	RFile::Write() to a file within the monitored directory
       
  1888 	test.Next(_L("RFile::Write()"));
       
  1889 	TFileName path=_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.Doc");
       
  1890 	TRequestStatus reqStat(KRequestPending);
       
  1891 
       
  1892 	RFile file;
       
  1893 
       
  1894 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1895 	test(reqStat==KRequestPending);
       
  1896 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  1897 	test(r==KErrNone);
       
  1898 	User::WaitForRequest(reqStat);
       
  1899 	test(reqStat==KErrNone);
       
  1900 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1901 	test(reqStat==KRequestPending);
       
  1902 	r=file.Write(0,_L8("Pay no attention to the man behind the curtain"));
       
  1903 	test(r==KErrNone);
       
  1904 	file.Close();
       
  1905 	User::WaitForRequest(reqStat);
       
  1906 	test(reqStat==KErrNone);
       
  1907 
       
  1908 //	RFile::Read() a file within the monitored directory - no notification for reads
       
  1909 	path=_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\");
       
  1910 	TBuf8<100> temp;
       
  1911 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1912 	test(reqStat==KRequestPending);
       
  1913 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  1914 	test(r==KErrNone);
       
  1915 	test(reqStat==KRequestPending);
       
  1916 	r=file.Read(0,temp,100);
       
  1917 	test(reqStat==KRequestPending);
       
  1918 
       
  1919 //	RFile::SetAtt() of a file within the monitored directory
       
  1920 	test.Next(_L("RFile::SetAtt()"));
       
  1921 	r=file.SetAtt(KEntryAttSystem,KEntryAttNormal);
       
  1922 	test(r==KErrNone);
       
  1923 	User::WaitForRequest(reqStat);
       
  1924 	test(reqStat==KErrNone);
       
  1925 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1926 	test(reqStat==KRequestPending);
       
  1927 
       
  1928 //	RFile::SetSize() of a file within the monitored directory
       
  1929 	test.Next(_L("RFile::SetSize()"));
       
  1930 	r=file.SetSize(256);
       
  1931 	test(r==KErrNone);
       
  1932 	User::WaitForRequest(reqStat);
       
  1933 	test(reqStat==KErrNone);
       
  1934 	file.Close();
       
  1935 
       
  1936 //	RFile::Temp() to create a temp file within the monitored directory
       
  1937 	test.Next(_L("RFile::Temp()"));
       
  1938 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1939 	test(reqStat==KRequestPending);
       
  1940 	TFileName fileName;
       
  1941 	r=file.Temp(TheFs,path,fileName,EFileWrite);
       
  1942 	test(r==KErrNone);
       
  1943 	User::WaitForRequest(reqStat);
       
  1944 	test(reqStat==KErrNone);
       
  1945 	file.Close();
       
  1946 
       
  1947 //	RFile::SetModified() to change modification time of a file within monitored dir
       
  1948 	test.Next(_L("RFile::SetModified()"));
       
  1949 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1950 	test(reqStat==KRequestPending);
       
  1951 	TTime now;
       
  1952 	now.HomeTime();
       
  1953 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  1954 	test(r==KErrNone);
       
  1955 	test(reqStat==KRequestPending);
       
  1956 	file.SetModified(now);
       
  1957 	file.Close();
       
  1958 	User::WaitForRequest(reqStat);
       
  1959 	test(reqStat==KErrNone);
       
  1960 
       
  1961 //	RFs::SetEntry() to change a directory entry within the monitored directory
       
  1962 	test.Next(_L("RFs::SetEntry()"));
       
  1963 	TEntry entry;
       
  1964 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1965 	r=TheFs.Entry(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),entry);
       
  1966 	test(reqStat==KRequestPending);
       
  1967 	now.HomeTime();
       
  1968 	r=TheFs.SetEntry(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),now,KEntryAttHidden,KEntryAttNormal);
       
  1969 	test(r==KErrNone);
       
  1970 	User::WaitForRequest(reqStat);
       
  1971 	test(reqStat==KErrNone);
       
  1972 
       
  1973 //	RFile::Set() to change file's modification time and attributes
       
  1974 	test.Next(_L("RFile::Set()"));
       
  1975 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1976 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  1977 	test(r==KErrNone);
       
  1978 	test(reqStat==KRequestPending);
       
  1979 	now.HomeTime();
       
  1980 	r=file.Set(now,KEntryAttNormal,KEntryAttHidden);
       
  1981 	file.Close();
       
  1982 	User::WaitForRequest(reqStat);
       
  1983 	test(reqStat==KErrNone);
       
  1984 
       
  1985 //	RFs::SetDriveName()
       
  1986 	test.Next(_L("RFs::SetDriveName()"));
       
  1987 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  1988 	test(reqStat==KRequestPending);
       
  1989 	User::After(KNotifyChangeAfter);
       
  1990 	r=TheFs.SetDriveName(KDefaultDrive,_L("DRIVETEST"));
       
  1991 	test(r==KErrNone);
       
  1992 	User::WaitForRequest(reqStat);
       
  1993 	test(reqStat==KErrNone);
       
  1994 	fs.NotifyChange(ENotifyEntry,reqStat,path);
       
  1995 	User::After(KNotifyChangeAfter);
       
  1996 	r=TheFs.SetDriveName(KDefaultDrive,_L("TEST"));
       
  1997 	test(r==KErrNone);
       
  1998 	test(reqStat==KRequestPending);
       
  1999 	fs.NotifyChangeCancel(reqStat);
       
  2000 	User::WaitForRequest(reqStat);
       
  2001 	test(reqStat==KErrCancel);
       
  2002 	fs.NotifyChange(ENotifyDisk,reqStat,path);
       
  2003 	User::After(KNotifyChangeAfter);
       
  2004 	r=TheFs.SetDriveName(KDefaultDrive,_L("DRIVE"));
       
  2005 	test(r==KErrNone);
       
  2006 	test(reqStat==KRequestPending);
       
  2007 	fs.NotifyChangeCancel(reqStat);
       
  2008 	User::WaitForRequest(reqStat);
       
  2009 	test(reqStat==KErrCancel);
       
  2010 
       
  2011 
       
  2012 //	RFs::MkDir()
       
  2013 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2014 	test(reqStat==KRequestPending);
       
  2015 	test.Next(_L("RFs::MkDir()"));
       
  2016 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\EMERALD_CITY\\"));
       
  2017 	test(r==KErrNone);
       
  2018 	User::WaitForRequest(reqStat);
       
  2019 	test(reqStat==KErrNone);
       
  2020 
       
  2021 //	RFs::RmDir()
       
  2022 	test.Next(_L("RFs::RmDir()"));
       
  2023 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2024 	test(reqStat==KRequestPending);
       
  2025 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\EMERALD_CITY\\"));
       
  2026 	test(r==KErrNone);
       
  2027 	User::WaitForRequest(reqStat);
       
  2028 	test(reqStat==KErrNone);
       
  2029 
       
  2030 //	RFile::Create()
       
  2031 	test.Next(_L("RFile::Create()"));
       
  2032 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2033 	test(reqStat==KRequestPending);
       
  2034 	r=file.Create(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"),EFileRead|EFileWrite);
       
  2035 	test(r==KErrNone);
       
  2036 	User::WaitForRequest(reqStat);
       
  2037 	test(reqStat==KErrNone);
       
  2038 	file.Close();
       
  2039 
       
  2040 //	RFs::Delete()
       
  2041 	test.Next(_L("RFs::Delete()"));
       
  2042 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2043 	test(reqStat==KRequestPending);
       
  2044 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"));
       
  2045 	test(r==KErrNone);
       
  2046 	User::WaitForRequest(reqStat);
       
  2047 	test(reqStat==KErrNone);
       
  2048 
       
  2049 //	RFile::Replace()
       
  2050 	test.Next(_L("RFile::Replace()"));
       
  2051 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2052 	test(reqStat==KRequestPending);
       
  2053 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"),EFileRead|EFileWrite);
       
  2054 	test(r==KErrNone);
       
  2055 	User::WaitForRequest(reqStat);
       
  2056 	test(reqStat==KErrNone);
       
  2057 	file.Close();
       
  2058 
       
  2059 //	RFs::Delete()
       
  2060 	test.Next(_L("RFs::Delete()"));
       
  2061 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2062 	test(reqStat==KRequestPending);
       
  2063 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"));
       
  2064 	test(r==KErrNone);
       
  2065 	User::WaitForRequest(reqStat);
       
  2066 	test(reqStat==KErrNone);
       
  2067 
       
  2068 //	RFs::SetVolumeLabel() - should only be notification when monitoring relevant TNotifyTypes
       
  2069 	test.Next(_L("RFs::SetVolumeLabel"));
       
  2070 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2071 
       
  2072 	TInt driveNum=CurrentDrive();
       
  2073 	TVolumeInfo volInfo;
       
  2074 	TFileName currentVolName;
       
  2075 
       
  2076 	r=TheFs.Volume(volInfo,driveNum);
       
  2077 	test(r==KErrNone);
       
  2078 	test(reqStat==KRequestPending);
       
  2079 	currentVolName=volInfo.iName;
       
  2080 
       
  2081 	r=TheFs.SetVolumeLabel(_L("VOL"),driveNum);
       
  2082 	if (r==KErrNone)
       
  2083 		{
       
  2084 		User::WaitForRequest(reqStat);
       
  2085 		test(reqStat==KErrNone);
       
  2086 		r=TheFs.Volume(volInfo,driveNum);
       
  2087 		test(r==KErrNone);
       
  2088 		test(volInfo.iName==_L("VOL"));
       
  2089 	//	Test notification occurs under ENotifyDisk
       
  2090 		fs.NotifyChange(ENotifyDisk,reqStat,path);
       
  2091 		test(reqStat==KRequestPending);
       
  2092 		r=TheFs.SetVolumeLabel(_L("ABCDEFGHIJK"),driveNum);
       
  2093 		test(r==KErrNone);
       
  2094 		User::WaitForRequest(reqStat);
       
  2095 		test(reqStat==KErrNone);
       
  2096 		r=TheFs.Volume(volInfo,driveNum);
       
  2097 		test(r==KErrNone);
       
  2098 
       
  2099 		test(volInfo.iName==_L("ABCDEFGHIJK"));
       
  2100 
       
  2101 	//	Test notification does not occur under ENotifyAttributes
       
  2102 		fs.NotifyChange(ENotifyAttributes,reqStat,path);
       
  2103 		r=TheFs.SetVolumeLabel(_L("TROPICANA"),driveNum);
       
  2104 		test(r==KErrNone);
       
  2105 		test(reqStat==KRequestPending);
       
  2106 		r=TheFs.Volume(volInfo,driveNum);
       
  2107 		test(r==KErrNone);
       
  2108 
       
  2109 		test(volInfo.iName==_L("TROPICANA"));
       
  2110 
       
  2111 		fs.NotifyChangeCancel(reqStat);
       
  2112 		User::WaitForRequest(reqStat);
       
  2113 		test(reqStat==KErrCancel);
       
  2114 	//	Test notification occurs under ENotifyEntry
       
  2115 		fs.NotifyChange(ENotifyEntry,reqStat,path);
       
  2116 		test(reqStat==KRequestPending);
       
  2117 		r=TheFs.SetVolumeLabel(currentVolName,driveNum);
       
  2118 		test(r==KErrNone);
       
  2119 		User::WaitForRequest(reqStat);
       
  2120 		test(reqStat==KErrNone);
       
  2121 		r=TheFs.Volume(volInfo,driveNum);
       
  2122 		test(r==KErrNone);
       
  2123 		test(volInfo.iName==currentVolName);
       
  2124 		}
       
  2125 
       
  2126 	else	//	RFs::SetVolumeLabel() doesn't work on subst drives
       
  2127 		{
       
  2128 		fs.NotifyChangeCancel();
       
  2129 		User::WaitForRequest(reqStat);
       
  2130 		test.Printf(_L("Cannot set volume label on a substed drive\n"));
       
  2131 		}
       
  2132 
       
  2133 
       
  2134 //	RFs::Rename()
       
  2135 
       
  2136 	test.Next(_L("RFs::Rename()"));
       
  2137 	fs.NotifyChange(ENotifyEntry,reqStat,path);
       
  2138 	test(reqStat==KRequestPending);
       
  2139 	r=TheFs.Rename(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Toto.doc"));
       
  2140 	test(r==KErrNone);
       
  2141 	User::WaitForRequest(reqStat);
       
  2142 	test(reqStat==KErrNone);
       
  2143 
       
  2144 	r=TheFs.Rename(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Toto.doc"),_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"));
       
  2145 	test(r==KErrNone);
       
  2146 
       
  2147 #if defined(__WINS__)
       
  2148 	if(gSessionPath[0]=='Y'||gSessionPath[0]=='X')
       
  2149 #endif
       
  2150 		{
       
  2151 		test.Next(_L("RFs::Rename() with max path length"));
       
  2152 		TFileName longName=_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\");
       
  2153 		while(longName.Length()<(KMaxFileName-2))
       
  2154 			longName+=_L("a");
       
  2155 		r=TheFs.Rename(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),longName);
       
  2156 		test(r==KErrNone);
       
  2157 		fs.NotifyChange(ENotifyEntry,reqStat,longName);
       
  2158 		test(reqStat==KRequestPending);
       
  2159 		r=TheFs.Rename(longName,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"));
       
  2160 		test(r==KErrNone);
       
  2161 		User::WaitForRequest(reqStat);
       
  2162 		test(reqStat==KErrNone);
       
  2163 		}
       
  2164 
       
  2165 	fs.Close();
       
  2166 	}
       
  2167 
       
  2168 
       
  2169 static void Test15()
       
  2170 
       
  2171 	{
       
  2172 //
       
  2173 //	Repeat Test15 operations in a subtree of that monitored, and ensure notification
       
  2174 //	occurs for a variety of RFile and RFs operations
       
  2175 //
       
  2176 	RFs fs;					//	Session to be notified when a change occurs
       
  2177 	TInt r=fs.Connect();
       
  2178 	test(r==KErrNone);
       
  2179 	r=fs.SetSessionPath(gSessionPath);
       
  2180 	test(r==KErrNone);
       
  2181 
       
  2182 //	RFile::Write() to a file in the subtree
       
  2183 	test.Next(_L("RFile::Write()"));
       
  2184 	TFileName path=_L("\\F32-TST\\NOTIFY\\");
       
  2185 	TRequestStatus reqStat(KRequestPending);
       
  2186 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2187 
       
  2188 	RFile file;
       
  2189 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  2190 	test(r==KErrNone);
       
  2191 	test(reqStat==KRequestPending);
       
  2192 	r=file.Write(0,_L8("Pay no attention to the man behind the curtain"));
       
  2193 	file.Close();
       
  2194 	User::WaitForRequest(reqStat);
       
  2195 	test(reqStat==KErrNone);
       
  2196 
       
  2197 //	RFile::Read() a file within the monitored directory - no notification for reads
       
  2198 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2199 	TBuf8<100> temp;
       
  2200 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  2201 	test(r==KErrNone);
       
  2202 	test(reqStat==KRequestPending);
       
  2203 	r=file.Read(0,temp,100);
       
  2204 	test(reqStat==KRequestPending);
       
  2205 
       
  2206 //	RFile::SetAtt() of a file within the monitored directory
       
  2207 	test.Next(_L("RFile::SetAtt()"));
       
  2208 	r=file.SetAtt(KEntryAttNormal,KEntryAttHidden);
       
  2209 	test(r==KErrNone);
       
  2210 	User::WaitForRequest(reqStat);
       
  2211 	test(reqStat==KErrNone);
       
  2212 
       
  2213 //	RFile::SetSize() of a file within the monitored directory
       
  2214 	test.Next(_L("RFile::SetSize()"));
       
  2215 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2216 	test(reqStat==KRequestPending);
       
  2217 	r=file.SetSize(256);
       
  2218 	test(r==KErrNone);
       
  2219 	User::WaitForRequest(reqStat);
       
  2220 	test(reqStat==KErrNone);
       
  2221 	file.Close();
       
  2222 
       
  2223 //	RFile::Temp() to create a temp file in the subtree
       
  2224 	test.Next(_L("RFile::Temp()"));
       
  2225 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2226 	test(reqStat==KRequestPending);
       
  2227 	TFileName fileName;
       
  2228 	r=file.Temp(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\"),fileName,EFileWrite);
       
  2229 	test(r==KErrNone);
       
  2230 	User::WaitForRequest(reqStat);
       
  2231 	test(reqStat==KErrNone);
       
  2232 	file.Close();
       
  2233 
       
  2234 //	RFile::SetModified() to change modification time of a file within monitored dir
       
  2235 	test.Next(_L("RFile::SetModified()"));
       
  2236 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2237 	TTime now;
       
  2238 	now.HomeTime();
       
  2239 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  2240 	test(r==KErrNone);
       
  2241 	test(reqStat==KRequestPending);
       
  2242 	file.SetModified(now);
       
  2243 	file.Close();
       
  2244 	User::WaitForRequest(reqStat);
       
  2245 	test(reqStat==KErrNone);
       
  2246 
       
  2247 //	RFs::Entry() to change a directory entry within the monitored directory
       
  2248 	test.Next(_L("RFs::Entry()"));
       
  2249 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2250 	TEntry entry;
       
  2251 	r=TheFs.Entry(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),entry);
       
  2252 	test(reqStat==KRequestPending);
       
  2253 	now.HomeTime();
       
  2254 	r=TheFs.SetEntry(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),now,KEntryAttHidden,KEntryAttNormal);
       
  2255 	test(r==KErrNone);
       
  2256 	User::WaitForRequest(reqStat);
       
  2257 	test(reqStat==KErrNone);
       
  2258 
       
  2259 //	RFile::Set() to change file's modification time and attributes
       
  2260 	test.Next(_L("RFile::Set()"));
       
  2261 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2262 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  2263 	test(r==KErrNone);
       
  2264 	test(reqStat==KRequestPending);
       
  2265 	now.HomeTime();
       
  2266 	r=file.Set(now,KEntryAttNormal,KEntryAttHidden);
       
  2267 	file.Close();
       
  2268 	User::WaitForRequest(reqStat);
       
  2269 	test(reqStat==KErrNone);
       
  2270 
       
  2271 //	RFs::SetDriveName()
       
  2272 	test.Next(_L("RFs::SetDriveName()"));
       
  2273 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2274 	test(reqStat==KRequestPending);
       
  2275 	User::After(KNotifyChangeAfter);
       
  2276 	r=TheFs.SetDriveName(KDefaultDrive,_L("DRIVETEST"));
       
  2277 	test(r==KErrNone);
       
  2278 	User::WaitForRequest(reqStat);
       
  2279 	test(reqStat==KErrNone);
       
  2280 	fs.NotifyChange(ENotifyEntry,reqStat,path);
       
  2281 	r=TheFs.SetDriveName(KDefaultDrive,_L("TEST"));
       
  2282 	test(r==KErrNone);
       
  2283 	test(reqStat==KRequestPending);
       
  2284 	User::After(KNotifyChangeAfter);
       
  2285 	fs.NotifyChangeCancel(reqStat);
       
  2286 	User::WaitForRequest(reqStat);
       
  2287 	test(reqStat==KErrCancel);
       
  2288 	fs.NotifyChange(ENotifyDisk,reqStat,path);
       
  2289 	User::After(KNotifyChangeAfter);
       
  2290 	r=TheFs.SetDriveName(KDefaultDrive,_L("DRIVE"));
       
  2291 	test(r==KErrNone);
       
  2292 	test(reqStat==KRequestPending);
       
  2293 	fs.NotifyChangeCancel(reqStat);
       
  2294 	User::WaitForRequest(reqStat);
       
  2295 	test(reqStat==KErrCancel);
       
  2296 
       
  2297 //	RFs::MkDir()
       
  2298 	test.Next(_L("RFs::MkDir()"));
       
  2299 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2300 	test(reqStat==KRequestPending);
       
  2301 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\EMERALD_CITY\\"));
       
  2302 	test(r==KErrNone);
       
  2303 	User::WaitForRequest(reqStat);
       
  2304 	test(reqStat==KErrNone);
       
  2305 
       
  2306 //	RFs::RmDir()
       
  2307 	test.Next(_L("RFs::RmDir()"));
       
  2308 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2309 	test(reqStat==KRequestPending);
       
  2310 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\EMERALD_CITY\\"));
       
  2311 	test(r==KErrNone);
       
  2312 	User::WaitForRequest(reqStat);
       
  2313 	test(reqStat==KErrNone);
       
  2314 
       
  2315 //	RFile::Create()
       
  2316 	test.Next(_L("RFile::Create()"));
       
  2317 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2318 	test(reqStat==KRequestPending);
       
  2319 	r=file.Create(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"),EFileRead|EFileWrite);
       
  2320 	test(r==KErrNone);
       
  2321 	User::WaitForRequest(reqStat);
       
  2322 	test(reqStat==KErrNone);
       
  2323 	file.Close();
       
  2324 
       
  2325 //	RFs::Delete()
       
  2326 	test.Next(_L("RFs::Delete()"));
       
  2327 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2328 	test(reqStat==KRequestPending);
       
  2329 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"));
       
  2330 	test(r==KErrNone);
       
  2331 	User::WaitForRequest(reqStat);
       
  2332 	test(reqStat==KErrNone);
       
  2333 
       
  2334 //	RFile::Replace()
       
  2335 	test.Next(_L("RFile::Replace()"));
       
  2336 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2337 	test(reqStat==KRequestPending);
       
  2338 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"),EFileRead|EFileWrite);
       
  2339 	test(r==KErrNone);
       
  2340 	User::WaitForRequest(reqStat);
       
  2341 	test(reqStat==KErrNone);
       
  2342 	file.Close();
       
  2343 
       
  2344 //	RFs::Delete()
       
  2345 	test.Next(_L("RFs::Delete()"));
       
  2346 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2347 	test(reqStat==KRequestPending);
       
  2348 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"));
       
  2349 	test(r==KErrNone);
       
  2350 	User::WaitForRequest(reqStat);
       
  2351 	test(reqStat==KErrNone);
       
  2352 
       
  2353 //	RFs::SetVolumeLabel() - should be notification under relevant TNotifyType monitoring
       
  2354 //	The operation is non-path specific so all outstanding interested requests are notified
       
  2355 	test.Next(_L("RFs::SetVolumeLabel()"));
       
  2356 
       
  2357 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2358 
       
  2359 	TInt driveNum=CurrentDrive();
       
  2360 	TVolumeInfo volInfo;
       
  2361 	TFileName currentVolName;
       
  2362 	r=TheFs.Volume(volInfo,driveNum);
       
  2363 	test(r==KErrNone);
       
  2364 	test(reqStat==KRequestPending);
       
  2365 	currentVolName=volInfo.iName;
       
  2366 
       
  2367 	r=TheFs.SetVolumeLabel(_L("VOL"),driveNum);
       
  2368 	if (r==KErrNone)
       
  2369 		{
       
  2370 		User::WaitForRequest(reqStat);
       
  2371 		test(reqStat==KErrNone);
       
  2372 		r=TheFs.Volume(volInfo,driveNum);
       
  2373 		test(r==KErrNone);
       
  2374 		test(volInfo.iName==_L("VOL"));
       
  2375 	//	Test notification occurs under ENotifyDisk
       
  2376 		fs.NotifyChange(ENotifyDisk,reqStat,path);
       
  2377 		test(reqStat==KRequestPending);
       
  2378 		r=TheFs.SetVolumeLabel(_L("ABCDEFGHIJK"),driveNum);
       
  2379 		test(r==KErrNone);
       
  2380 		User::WaitForRequest(reqStat);
       
  2381 		test(reqStat==KErrNone);
       
  2382 		r=TheFs.Volume(volInfo,driveNum);
       
  2383 		test(r==KErrNone);
       
  2384 
       
  2385 		test(volInfo.iName==_L("ABCDEFGHIJK"));
       
  2386 
       
  2387 	//	Test notification does not occur under ENotifyAttributes
       
  2388 		fs.NotifyChange(ENotifyAttributes,reqStat,path);
       
  2389 		r=TheFs.SetVolumeLabel(_L("TROPICANA"),driveNum);
       
  2390 		test(r==KErrNone);
       
  2391 		test(reqStat==KRequestPending);
       
  2392 		r=TheFs.Volume(volInfo,driveNum);
       
  2393 		test(r==KErrNone);
       
  2394 
       
  2395 		test(volInfo.iName==_L("TROPICANA"));
       
  2396 
       
  2397 		fs.NotifyChangeCancel(reqStat);
       
  2398 		User::WaitForRequest(reqStat);
       
  2399 		test(reqStat==KErrCancel);
       
  2400 	//	Test notification occurs under ENotifyEntry
       
  2401 		fs.NotifyChange(ENotifyEntry,reqStat,path);
       
  2402 		test(reqStat==KRequestPending);
       
  2403 		r=TheFs.SetVolumeLabel(currentVolName,driveNum);
       
  2404 		test(r==KErrNone);
       
  2405 		User::WaitForRequest(reqStat);
       
  2406 		test(reqStat==KErrNone);
       
  2407 		r=TheFs.Volume(volInfo,driveNum);
       
  2408 		test(r==KErrNone);
       
  2409 		test(volInfo.iName==currentVolName);
       
  2410 		}
       
  2411 
       
  2412 	else	//	RFs::SetVolumeLabel() doesn't work on subst drives
       
  2413 		{
       
  2414 		fs.NotifyChangeCancel();
       
  2415 		User::WaitForRequest(reqStat);
       
  2416 		test.Printf(_L("Cannot set volume label on a substed drive\n"));
       
  2417 		}
       
  2418 
       
  2419 
       
  2420 
       
  2421 //	Test that notification is made when change is made to monitored directory
       
  2422 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2423 	test(reqStat==KRequestPending);
       
  2424 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\EMERALD_CITY\\"));
       
  2425 	test(r==KErrNone);
       
  2426 	User::WaitForRequest(reqStat);
       
  2427 	test(reqStat==KErrNone);
       
  2428 
       
  2429 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2430 	test(reqStat==KRequestPending);
       
  2431 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\EMERALD_CITY\\"));
       
  2432 	test(r==KErrNone);
       
  2433 	User::WaitForRequest(reqStat);
       
  2434 	test(reqStat==KErrNone);
       
  2435 	fs.Close();
       
  2436 	}
       
  2437 
       
  2438 
       
  2439 static void Test16()
       
  2440 
       
  2441 	{
       
  2442 //
       
  2443 //	Repeat Test15 operations in a subtree of that monitored, and ensure notification
       
  2444 //	does occur for a variety of file operations when subtree watching is on
       
  2445 //
       
  2446 	RFs fs;
       
  2447 	TInt r=fs.Connect();	//	Session to be notified when a change occurs
       
  2448 	test(r==KErrNone);
       
  2449 	r=fs.SetSessionPath(gSessionPath);
       
  2450 	test(r==KErrNone);
       
  2451 
       
  2452 //	RFile::Write() to a file in the subtree
       
  2453 	TFileName path=_L("\\F32-TST\\NOTIFY\\");
       
  2454 	TRequestStatus reqStat(KRequestPending);
       
  2455 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2456 
       
  2457 	RFile file;
       
  2458 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  2459 	test(r==KErrNone);
       
  2460 	test(reqStat==KRequestPending);
       
  2461 	r=file.Write(0,_L8("Pay no attention to the man behind the curtain"));
       
  2462 	file.Close();
       
  2463 	User::WaitForRequest(reqStat);
       
  2464 	test(reqStat==KErrNone);
       
  2465 
       
  2466 //	RFile::Read() a file within the monitored directory - no notification for reads
       
  2467 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2468 	TBuf8<100> temp;
       
  2469 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  2470 	test(r==KErrNone);
       
  2471 	test(reqStat==KRequestPending);
       
  2472 	r=file.Read(0,temp,100);
       
  2473 	test(reqStat==KRequestPending);
       
  2474 
       
  2475 //	RFile::SetAtt() of a file within the monitored directory
       
  2476 	r=file.SetAtt(KEntryAttNormal,KEntryAttHidden);
       
  2477 	test(r==KErrNone);
       
  2478 	User::WaitForRequest(reqStat);
       
  2479 	test(reqStat==KErrNone);
       
  2480 
       
  2481 //	RFile::SetSize() of a file within the monitored directory
       
  2482 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2483 	test(reqStat==KRequestPending);
       
  2484 	r=file.SetSize(256);
       
  2485 	test(r==KErrNone);
       
  2486 	User::WaitForRequest(reqStat);
       
  2487 	test(reqStat==KErrNone);
       
  2488 	file.Close();
       
  2489 
       
  2490 
       
  2491 //	RFile::SetModified() to change modification time of a file within monitored dir
       
  2492 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2493 	TTime now;
       
  2494 	now.HomeTime();
       
  2495 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  2496 	test(r==KErrNone);
       
  2497 	test(reqStat==KRequestPending);
       
  2498 	file.SetModified(now);
       
  2499 	file.Close();
       
  2500 	User::WaitForRequest(reqStat);
       
  2501 	test(reqStat==KErrNone);
       
  2502 
       
  2503 //	RFs::Entry() to change a directory entry within the monitored directory
       
  2504 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2505 	TEntry entry;
       
  2506 	r=TheFs.Entry(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),entry);
       
  2507 	test(reqStat==KRequestPending);
       
  2508 	now.HomeTime();
       
  2509 	r=TheFs.SetEntry(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),now,KEntryAttHidden,KEntryAttNormal);
       
  2510 	test(r==KErrNone);
       
  2511 	User::WaitForRequest(reqStat);
       
  2512 	test(reqStat==KErrNone);
       
  2513 
       
  2514 //	RFile::Set() to change file's modification time and attributes
       
  2515 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2516 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),EFileRead|EFileWrite);
       
  2517 	test(r==KErrNone);
       
  2518 	test(reqStat==KRequestPending);
       
  2519 	now.HomeTime();
       
  2520 	r=file.Set(now,KEntryAttNormal,KEntryAttHidden);
       
  2521 	file.Close();
       
  2522 	User::WaitForRequest(reqStat);
       
  2523 	test(reqStat==KErrNone);
       
  2524 
       
  2525 //	RFs::SetDriveName() - should be no notification ever with extended notification
       
  2526 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2527 	test(reqStat==KRequestPending);
       
  2528 	User::After(KNotifyChangeAfter);
       
  2529 	r=TheFs.SetDriveName(KDefaultDrive,_L("DRIVETEST"));
       
  2530 	test(r==KErrNone);
       
  2531 	User::WaitForRequest(reqStat);
       
  2532 	test(reqStat==KErrNone);
       
  2533 	fs.NotifyChange(ENotifyEntry,reqStat,path);
       
  2534 	User::After(KNotifyChangeAfter);
       
  2535 	r=TheFs.SetDriveName(KDefaultDrive,_L("TEST"));
       
  2536 	test(r==KErrNone);
       
  2537 	test(reqStat==KRequestPending);
       
  2538 	fs.NotifyChangeCancel(reqStat);
       
  2539 	User::WaitForRequest(reqStat);
       
  2540 	fs.NotifyChange(ENotifyDisk,reqStat,path);
       
  2541 	User::After(KNotifyChangeAfter);
       
  2542 	r=TheFs.SetDriveName(KDefaultDrive,_L("DRIVE"));
       
  2543 	test(r==KErrNone);
       
  2544 	test(reqStat==KRequestPending);
       
  2545 	fs.NotifyChangeCancel(reqStat);
       
  2546 	User::WaitForRequest(reqStat);
       
  2547 	test(reqStat==KErrCancel);
       
  2548 
       
  2549 
       
  2550 //	RFs::MkDir()
       
  2551 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2552 	test(reqStat==KRequestPending);
       
  2553 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\EMERALD_CITY\\"));
       
  2554 	test(r==KErrNone);
       
  2555 	User::WaitForRequest(reqStat);
       
  2556 	test(reqStat==KErrNone);
       
  2557 
       
  2558 //	RFs::RmDir()
       
  2559 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2560 	test(reqStat==KRequestPending);
       
  2561 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\EMERALD_CITY\\"));
       
  2562 	test(r==KErrNone);
       
  2563 	User::WaitForRequest(reqStat);
       
  2564 	test(reqStat==KErrNone);
       
  2565 
       
  2566 //	RFile::Create()
       
  2567 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2568 	test(reqStat==KRequestPending);
       
  2569 	r=file.Create(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"),EFileRead|EFileWrite);
       
  2570 	test(r==KErrNone);
       
  2571 	User::WaitForRequest(reqStat);
       
  2572 	test(reqStat==KErrNone);
       
  2573 	file.Close();
       
  2574 
       
  2575 //	RFs::Delete()
       
  2576 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2577 	test(reqStat==KRequestPending);
       
  2578 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"));
       
  2579 	test(r==KErrNone);
       
  2580 	User::WaitForRequest(reqStat);
       
  2581 	test(reqStat==KErrNone);
       
  2582 
       
  2583 //	RFile::Replace()
       
  2584 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2585 	test(reqStat==KRequestPending);
       
  2586 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"),EFileRead|EFileWrite);
       
  2587 	test(r==KErrNone);
       
  2588 	User::WaitForRequest(reqStat);
       
  2589 	test(reqStat==KErrNone);
       
  2590 	file.Close();
       
  2591 
       
  2592 //	RFs::Delete()
       
  2593 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2594 	test(reqStat==KRequestPending);
       
  2595 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Good_Witch.bat"));
       
  2596 	test(r==KErrNone);
       
  2597 	User::WaitForRequest(reqStat);
       
  2598 	test(reqStat==KErrNone);
       
  2599 
       
  2600 //	RFs::SetVolumeLabel()
       
  2601 //	Not path specific, so all outstanding requests of correct TNotifyType are notified
       
  2602 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2603 	TInt driveNum=CurrentDrive();
       
  2604 	TVolumeInfo volInfo;
       
  2605 	TFileName currentVolName;
       
  2606 	r=TheFs.Volume(volInfo,driveNum);
       
  2607 	test(r==KErrNone);
       
  2608 	test(reqStat==KRequestPending);
       
  2609 	currentVolName=volInfo.iName;
       
  2610 
       
  2611 	r=TheFs.SetVolumeLabel(_L("VOL"),driveNum);
       
  2612 	if (r==KErrNone)
       
  2613 		{
       
  2614 		User::WaitForRequest(reqStat);
       
  2615 		test(reqStat==KErrNone);
       
  2616 		r=TheFs.Volume(volInfo,driveNum);
       
  2617 		test(r==KErrNone);
       
  2618 		test(volInfo.iName==_L("VOL"));
       
  2619 	//	Test notification occurs under ENotifyDisk
       
  2620 		fs.NotifyChange(ENotifyDisk,reqStat,path);
       
  2621 		test(reqStat==KRequestPending);
       
  2622 		r=TheFs.SetVolumeLabel(_L("ABCDEFGHIJK"),driveNum);
       
  2623 		test(r==KErrNone);
       
  2624 		User::WaitForRequest(reqStat);
       
  2625 		test(reqStat==KErrNone);
       
  2626 		r=TheFs.Volume(volInfo,driveNum);
       
  2627 		test(r==KErrNone);
       
  2628 
       
  2629 		test(volInfo.iName==_L("ABCDEFGHIJK"));
       
  2630 
       
  2631 	//	Test notification does not occur under ENotifyAttributes
       
  2632 		fs.NotifyChange(ENotifyAttributes,reqStat,path);
       
  2633 		r=TheFs.SetVolumeLabel(_L("TROPICANA"),driveNum);
       
  2634 		test(r==KErrNone);
       
  2635 		test(reqStat==KRequestPending);
       
  2636 		r=TheFs.Volume(volInfo,driveNum);
       
  2637 		test(r==KErrNone);
       
  2638 
       
  2639 		test(volInfo.iName==_L("TROPICANA"));
       
  2640 
       
  2641 		fs.NotifyChangeCancel(reqStat);
       
  2642 		User::WaitForRequest(reqStat);
       
  2643 		test(reqStat==KErrCancel);
       
  2644 	//	Test notification occurs under ENotifyEntry
       
  2645 		fs.NotifyChange(ENotifyEntry,reqStat,path);
       
  2646 		test(reqStat==KRequestPending);
       
  2647 		r=TheFs.SetVolumeLabel(currentVolName,driveNum);
       
  2648 		test(r==KErrNone);
       
  2649 		User::WaitForRequest(reqStat);
       
  2650 		test(reqStat==KErrNone);
       
  2651 		r=TheFs.Volume(volInfo,driveNum);
       
  2652 		test(r==KErrNone);
       
  2653 		test(volInfo.iName==currentVolName);
       
  2654 		}
       
  2655 
       
  2656 	else	//	RFs::SetVolumeLabel() doesn't work on subst drives
       
  2657 		{
       
  2658 		fs.NotifyChangeCancel();
       
  2659 		User::WaitForRequest(reqStat);
       
  2660 		test.Printf(_L("Cannot set volume label on a substed drive\n"));
       
  2661 		}
       
  2662 
       
  2663 //	RFs::Rename()
       
  2664 	fs.NotifyChange(ENotifyEntry,reqStat,path);
       
  2665 	test(reqStat==KRequestPending);
       
  2666 	r=TheFs.Rename(_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Dorothy.doc"),_L("\\F32-TST\\NOTIFY\\MUNCHKINS\\Toto.doc"));
       
  2667 	test(r==KErrNone);
       
  2668 	User::WaitForRequest(reqStat);
       
  2669 	test(reqStat==KErrNone);
       
  2670 
       
  2671 //	Test that notification is made when change is made to monitored directory
       
  2672 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2673 	test(reqStat==KRequestPending);
       
  2674 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\EMERALD_CITY\\"));
       
  2675 	test(r==KErrNone);
       
  2676 	User::WaitForRequest(reqStat);
       
  2677 	test(reqStat==KErrNone);
       
  2678 
       
  2679 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2680 	test(reqStat==KRequestPending);
       
  2681 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\EMERALD_CITY\\"));
       
  2682 	test(r==KErrNone);
       
  2683 	User::WaitForRequest(reqStat);
       
  2684 	test(reqStat==KErrNone);
       
  2685 	fs.Close();
       
  2686 	}
       
  2687 
       
  2688 
       
  2689 static void Test17()
       
  2690 //
       
  2691 //	Test multiple requests from a single session
       
  2692 //
       
  2693 	{
       
  2694 
       
  2695 	test.Next(_L("Test reads and writes do not cause notification under ENotifyEntry"));
       
  2696 
       
  2697 	RFile file;
       
  2698 	TInt r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\kangaroo.txt"),EFileRead|EFileWrite);
       
  2699 	test(r==KErrNone);
       
  2700 	file.Close();
       
  2701 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\koala.txt"),EFileRead|EFileWrite);
       
  2702 	test(r==KErrNone);
       
  2703 	file.Close();
       
  2704 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\dingo.txt"),EFileRead|EFileWrite);
       
  2705 	test(r==KErrNone);
       
  2706 	file.Close();
       
  2707 
       
  2708 	RFs fs;
       
  2709 	r=fs.Connect();
       
  2710 	test(r==KErrNone);
       
  2711 	r=fs.SetSessionPath(gSessionPath);
       
  2712 	test(r==KErrNone);
       
  2713 
       
  2714 	TRequestStatus reqStat1(KRequestPending);
       
  2715 	TFileName path1=_L("\\F32-TST\\NOTIFY\\");
       
  2716 	fs.NotifyChange(ENotifyEntry,reqStat1,path1);
       
  2717 
       
  2718 	TRequestStatus status1(KRequestPending);
       
  2719 	TRequestStatus status2(KRequestPending);
       
  2720 	TRequestStatus status3(KRequestPending);
       
  2721 	TRequestStatus status4(KRequestPending);
       
  2722 	TRequestStatus status5(KRequestPending);
       
  2723 	TRequestStatus status6(KRequestPending);
       
  2724 
       
  2725 	TRequestStatus statusExtended1(KRequestPending);
       
  2726 	TRequestStatus statusExtended2(KRequestPending);
       
  2727 	TRequestStatus statusExtended3(KRequestPending);
       
  2728 	TRequestStatus statusExtended4(KRequestPending);
       
  2729 	TRequestStatus statusExtended5(KRequestPending);
       
  2730 	TRequestStatus statusExtended6(KRequestPending);
       
  2731 
       
  2732 //	Request multiple notifications using standard change notification request
       
  2733 	fs.NotifyChange(ENotifyEntry,status1);
       
  2734 	fs.NotifyChange(ENotifyEntry,status2);
       
  2735 	fs.NotifyChange(ENotifyEntry,status3);
       
  2736 	fs.NotifyChange(ENotifyEntry,status4);
       
  2737 	fs.NotifyChange(ENotifyEntry,status5);
       
  2738 	fs.NotifyChange(ENotifyEntry,status6);
       
  2739 
       
  2740 //	Request multiple notifications using extended change notification request
       
  2741 	fs.NotifyChange(ENotifyEntry,statusExtended1,path1);
       
  2742 	fs.NotifyChange(ENotifyEntry,statusExtended2,path1);
       
  2743 	fs.NotifyChange(ENotifyEntry,statusExtended3,path1);
       
  2744 	fs.NotifyChange(ENotifyEntry,statusExtended4,path1);
       
  2745 	fs.NotifyChange(ENotifyEntry,statusExtended5,path1);
       
  2746 	fs.NotifyChange(ENotifyEntry,statusExtended6,path1);
       
  2747 
       
  2748 	TRequestStatus reqStat2(KRequestPending);
       
  2749 	TFileName path2=_L("\\F32-TST\\NOTIFY\\kangaroo.txt");
       
  2750 	fs.NotifyChange(ENotifyEntry,reqStat2,path2);
       
  2751 
       
  2752 	TRequestStatus reqStat3(KRequestPending);
       
  2753 	TFileName path3=_L("\\F32-TST\\NOTIFY\\koala.txt");
       
  2754 	fs.NotifyChange(ENotifyEntry,reqStat3,path3);
       
  2755 
       
  2756 	TRequestStatus reqStat4(KRequestPending);
       
  2757 	TFileName path4=_L("\\F32-TST\\NOTIFY\\dingo.txt");
       
  2758 	fs.NotifyChange(ENotifyEntry,reqStat4,path4);
       
  2759 
       
  2760 
       
  2761 	r=gSleepThread.CreateLocal(0);
       
  2762 	test(r==KErrNone);
       
  2763 	RThread thread1;
       
  2764 	r=thread1.Create(_L("TestThread1"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest5);
       
  2765 	test(r==KErrNone);
       
  2766 	thread1.Resume();
       
  2767 	gSleepThread.Wait();
       
  2768 
       
  2769 	test(status1==KRequestPending);
       
  2770 	test(status2==KRequestPending);
       
  2771 	test(status3==KRequestPending);
       
  2772 	test(status4==KRequestPending);
       
  2773 	test(status5==KRequestPending);
       
  2774 	test(status6==KRequestPending);
       
  2775 
       
  2776 	test(statusExtended1==KRequestPending);
       
  2777 	test(statusExtended2==KRequestPending);
       
  2778 	test(statusExtended3==KRequestPending);
       
  2779 	test(statusExtended4==KRequestPending);
       
  2780 	test(statusExtended5==KRequestPending);
       
  2781 	test(statusExtended6==KRequestPending);
       
  2782 
       
  2783 	test(reqStat1==KRequestPending);
       
  2784 	test(reqStat2==KRequestPending);
       
  2785 	test(reqStat3==KRequestPending);
       
  2786 	test(reqStat4==KRequestPending);
       
  2787 
       
  2788 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\kangaroo.txt"));
       
  2789 	test(r==KErrNone);
       
  2790 	User::WaitForRequest(reqStat1);
       
  2791 	test(reqStat1==KErrNone);
       
  2792 	User::WaitForRequest(status1);
       
  2793 	test(status1==KErrNone);
       
  2794 	User::WaitForRequest(status2);
       
  2795 	test(status2==KErrNone);
       
  2796 	User::WaitForRequest(status3);
       
  2797 	test(status3==KErrNone);
       
  2798 	User::WaitForRequest(status4);
       
  2799 	test(status4==KErrNone);
       
  2800 	User::WaitForRequest(status5);
       
  2801 	test(status5==KErrNone);
       
  2802 	User::WaitForRequest(status6);
       
  2803 	test(status6==KErrNone);
       
  2804 
       
  2805 	User::WaitForRequest(statusExtended1);
       
  2806 	test(statusExtended1==KErrNone);
       
  2807 	User::WaitForRequest(statusExtended2);
       
  2808 	test(statusExtended2==KErrNone);
       
  2809 	User::WaitForRequest(statusExtended3);
       
  2810 	test(statusExtended3==KErrNone);
       
  2811 	User::WaitForRequest(statusExtended4);
       
  2812 	test(statusExtended4==KErrNone);
       
  2813 	User::WaitForRequest(statusExtended5);
       
  2814 	test(statusExtended5==KErrNone);
       
  2815 	User::WaitForRequest(statusExtended6);
       
  2816 	test(statusExtended6==KErrNone);
       
  2817 
       
  2818 	User::WaitForRequest(reqStat2);
       
  2819 	test(reqStat2==KErrNone);
       
  2820 	test(reqStat3==KRequestPending);
       
  2821 	test(reqStat4==KRequestPending);
       
  2822 	fs.NotifyChangeCancel();	//	Cancels both remaining notification requests
       
  2823 
       
  2824 	User::WaitForRequest(reqStat3);
       
  2825 	User::WaitForRequest(reqStat4);
       
  2826 
       
  2827 	gSleepThread.Close();
       
  2828 	thread1.Close();
       
  2829 
       
  2830 	test.Next(_L("Test reads and writes do cause notification under ENotifyAll"));
       
  2831 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\kangaroo.txt"),EFileRead|EFileWrite);
       
  2832 	test(r==KErrNone);
       
  2833 	file.Close();
       
  2834 
       
  2835 	fs.NotifyChange(ENotifyAll,reqStat1,path1);
       
  2836 	fs.NotifyChange(ENotifyEntry,reqStat2,path2);
       
  2837 	fs.NotifyChange(ENotifyAll,reqStat3,path3);
       
  2838 	fs.NotifyChange(ENotifyEntry,reqStat4,path4);
       
  2839 	test(reqStat1==KRequestPending);
       
  2840 	test(reqStat2==KRequestPending);
       
  2841 	test(reqStat3==KRequestPending);
       
  2842 	test(reqStat4==KRequestPending);
       
  2843 
       
  2844 	r=gSleepThread.CreateLocal(0);
       
  2845 	test(r==KErrNone);
       
  2846 	RThread thread2;
       
  2847 	r=thread2.Create(_L("TestThread2"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest5);
       
  2848 	test(r==KErrNone);
       
  2849 	thread2.Resume();
       
  2850 	gSleepThread.Wait();
       
  2851 
       
  2852 	User::WaitForRequest(reqStat1);
       
  2853 	test(reqStat1==KErrNone);
       
  2854 	test(reqStat2==KRequestPending);
       
  2855 	User::WaitForRequest(reqStat3);
       
  2856 	test(reqStat3==KErrNone);
       
  2857 	test(reqStat4==KRequestPending);
       
  2858 
       
  2859 	gSleepThread.Close();
       
  2860 	thread2.Close();
       
  2861 
       
  2862 	fs.NotifyChange(ENotifyAll,reqStat1,path1);
       
  2863 	fs.NotifyChange(ENotifyAll,reqStat3,path3);
       
  2864 
       
  2865 	test(reqStat1==KRequestPending);
       
  2866 	test(reqStat2==KRequestPending);
       
  2867 	test(reqStat3==KRequestPending);
       
  2868 	test(reqStat4==KRequestPending);
       
  2869 
       
  2870 	r=gSleepThread.CreateLocal(0);
       
  2871 	test(r==KErrNone);
       
  2872 	RThread thread3;
       
  2873 	r=thread3.Create(_L("TestThread3"),ThreadEntryPoint,0x4000,KHeapSize,KHeapSize,(TAny*)ETest5);
       
  2874 	test(r==KErrNone);
       
  2875 	thread3.Resume();
       
  2876 	gSleepThread.Wait();
       
  2877 
       
  2878 	User::WaitForRequest(reqStat1);
       
  2879 	test(reqStat1==KErrNone);
       
  2880 	test(reqStat2==KRequestPending);	//	Monitoring with ENotifyEntry
       
  2881 	User::WaitForRequest(reqStat3);
       
  2882 	test(reqStat3==KErrNone);
       
  2883 	test(reqStat4==KRequestPending);	//	Monitoring with ENotifyEntry
       
  2884 
       
  2885 	RFs fs2;
       
  2886 	r=fs2.Connect();
       
  2887 	test(r==KErrNone);
       
  2888 	r=fs2.SetSessionPath(gSessionPath);
       
  2889 	test(r==KErrNone);
       
  2890 
       
  2891 	TRequestStatus reqStat(KRequestPending);
       
  2892 	fs2.NotifyChange(ENotifyEntry,reqStat);
       
  2893 	test(reqStat==KRequestPending);
       
  2894 
       
  2895 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\kangaroo.txt"));
       
  2896 	test(r==KErrNone);
       
  2897 	User::WaitForRequest(reqStat2);
       
  2898 	test(reqStat2==KErrNone);
       
  2899 	test(reqStat4==KRequestPending);
       
  2900 	User::WaitForRequest(reqStat);
       
  2901 	test(reqStat==KErrNone);
       
  2902 
       
  2903 	fs2.NotifyChange(ENotifyAll,reqStat);
       
  2904 	test(reqStat==KRequestPending);
       
  2905 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\koala.txt"));
       
  2906 	test(r==KErrNone);
       
  2907 	User::WaitForRequest(reqStat);
       
  2908 	test(reqStat==KErrNone);
       
  2909 	test(reqStat4==KRequestPending);
       
  2910 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\dingo.txt"));
       
  2911 	test(r==KErrNone);
       
  2912 	User::WaitForRequest(reqStat4);
       
  2913 	test(reqStat4==KErrNone);
       
  2914 
       
  2915 	gSleepThread.Close();
       
  2916 	thread3.Close();
       
  2917 	fs.Close();
       
  2918 	}
       
  2919 
       
  2920 static void Test18()
       
  2921 
       
  2922 	{
       
  2923 //
       
  2924 //	Test notification request succeeds or fails as appropriate to the notification type
       
  2925 //	with all file operations which result in notifications
       
  2926 //	enum TNotifyType {ENotifyEntry=0x00,ENotifyAll=0x01,ENotifyFile=0x04,ENotifyDir=0x08,
       
  2927 //				ENotifyAttributes=0x10,ENotifyWrite=0x20,ENotifyDisk=0x40};
       
  2928 //
       
  2929 	RFs fs;
       
  2930 	TInt r=fs.Connect();	//	Session to be notified of any changes
       
  2931 	test(r==KErrNone);
       
  2932 	r=fs.SetSessionPath(gSessionPath);
       
  2933 	test(r==KErrNone);
       
  2934 
       
  2935 //	RFile::Write() to a file within the monitored directory
       
  2936 	test.Next(_L("RFile::Write()"));
       
  2937 	TFileName path=_L("\\F32-TST\\NOTIFY\\NewFile.txt");
       
  2938 	TRequestStatus reqStat(KRequestPending);
       
  2939 	TRequestStatus reqStat2(KRequestPending);
       
  2940 	TRequestStatus reqStat3(KRequestPending);
       
  2941 	TRequestStatus reqStat4(KRequestPending);
       
  2942 	TRequestStatus reqStat5(KRequestPending);
       
  2943 	TRequestStatus reqStat6(KRequestPending);
       
  2944 	TRequestStatus reqStat7(KRequestPending);
       
  2945 
       
  2946 
       
  2947 	RFile file;
       
  2948 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileWrite);
       
  2949 	test(r==KErrNone);
       
  2950 
       
  2951 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  2952 	fs.NotifyChange(ENotifyFile,reqStat2,path);
       
  2953 	fs.NotifyChange(ENotifyWrite,reqStat3,path);
       
  2954 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  2955 	fs.NotifyChange(ENotifyEntry,reqStat5,path);
       
  2956 	fs.NotifyChange(ENotifyAttributes,reqStat6,path);
       
  2957 	fs.NotifyChange(ENotifyDisk,reqStat7,path);
       
  2958 
       
  2959 
       
  2960 	test(reqStat==KRequestPending);
       
  2961 	test(reqStat2==KRequestPending);
       
  2962 	test(reqStat3==KRequestPending);
       
  2963 	User::WaitForRequest(reqStat4);
       
  2964 	test(reqStat4==KErrArgument); //	Cannot monitor a file with ENotifyDir
       
  2965 	test(reqStat5==KRequestPending);
       
  2966 	test(reqStat6==KRequestPending);
       
  2967 	fs.NotifyChange(ENotifyEntry,reqStat4,path);
       
  2968 	test(reqStat4==KRequestPending);
       
  2969 
       
  2970 	r=file.Write(0,_L8("Pay no attention to the man behind the curtain"));
       
  2971 	file.Close();
       
  2972 
       
  2973 	User::WaitForRequest(reqStat);
       
  2974 	test(reqStat==KErrNone);
       
  2975 	test(reqStat2==KRequestPending);	//	Monitoring with ENotifyFile
       
  2976 	User::WaitForRequest(reqStat3);
       
  2977 	test(reqStat3==KErrNone);
       
  2978 	test(reqStat4==KRequestPending);	//	Monitoring with ENotifyEntry
       
  2979 	test(reqStat5==KRequestPending);
       
  2980 	test(reqStat6==KRequestPending);
       
  2981 	test(reqStat7==KRequestPending);
       
  2982 	fs.NotifyChangeCancel();			//	Cancels all outstanding notification requests
       
  2983 
       
  2984 	User::WaitForRequest(reqStat2);
       
  2985 	test(reqStat2==KErrCancel);
       
  2986 	User::WaitForRequest(reqStat4);
       
  2987 	test(reqStat4==KErrCancel);
       
  2988 	User::WaitForRequest(reqStat5);
       
  2989 	test(reqStat5==KErrCancel);
       
  2990 	User::WaitForRequest(reqStat6);
       
  2991 	test(reqStat6==KErrCancel);
       
  2992 	User::WaitForRequest(reqStat7);
       
  2993 	test(reqStat7==KErrCancel);
       
  2994 
       
  2995 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileWrite);
       
  2996 	test(r==KErrNone);
       
  2997 
       
  2998 //	RFile::SetAtt() of a file within the monitored directory
       
  2999 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3000 	fs.NotifyChange(ENotifyFile,reqStat2,path);
       
  3001 	fs.NotifyChange(ENotifyEntry,reqStat3,path);
       
  3002 	fs.NotifyChange(ENotifyAttributes,reqStat4,path);
       
  3003 	fs.NotifyChange(ENotifyDir,reqStat5,path);
       
  3004 	fs.NotifyChange(ENotifyWrite,reqStat6,path);
       
  3005 	fs.NotifyChange(ENotifyDisk,reqStat7,path);
       
  3006 
       
  3007 	test(reqStat==KRequestPending);
       
  3008 	test(reqStat2==KRequestPending);
       
  3009 	test(reqStat3==KRequestPending);
       
  3010 	test(reqStat4==KRequestPending);
       
  3011 	User::WaitForRequest(reqStat5);
       
  3012 	test(reqStat5==KErrArgument);
       
  3013 	test(reqStat6==KRequestPending);
       
  3014 	test(reqStat7==KRequestPending);
       
  3015 
       
  3016 	test.Next(_L("RFile::SetAtt()"));
       
  3017 	r=file.SetAtt(KEntryAttSystem,KEntryAttNormal);
       
  3018 	test(r==KErrNone);
       
  3019 	User::WaitForRequest(reqStat);
       
  3020 	User::WaitForRequest(reqStat4);
       
  3021 	test(reqStat==KErrNone);
       
  3022 	test(reqStat2==KRequestPending);	//	Monitoring with ENotifyFile
       
  3023 	test(reqStat3==KRequestPending);	//	Monitoring with ENotifyEntry
       
  3024 	test(reqStat4==KErrNone);				//	Monitoring a file - can't use ENotifyDir
       
  3025 	test(reqStat6==KRequestPending);
       
  3026 	test(reqStat7==KRequestPending);
       
  3027 
       
  3028 	fs.NotifyChange(ENotifyWrite,reqStat,path);
       
  3029 	test(reqStat==KRequestPending);
       
  3030 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3031 	User::WaitForRequest(reqStat4);
       
  3032 	test(reqStat4==KErrArgument);
       
  3033 	r=file.SetAtt(KEntryAttNormal,KEntryAttSystem);
       
  3034 	test(r==KErrNone);
       
  3035 	test(reqStat==KRequestPending);		//	Monitoring with ENotifyWrite
       
  3036 	fs.NotifyChangeCancel();	//	Cancel outstanding notification request
       
  3037 
       
  3038 	User::WaitForRequest(reqStat);
       
  3039 	test(reqStat==KErrCancel);
       
  3040 	User::WaitForRequest(reqStat2);
       
  3041 	test(reqStat2==KErrCancel);
       
  3042 	User::WaitForRequest(reqStat3);
       
  3043 	test(reqStat3==KErrCancel);
       
  3044 	User::WaitForRequest(reqStat6);
       
  3045 	test(reqStat6==KErrCancel);
       
  3046 	User::WaitForRequest(reqStat7);
       
  3047 	test(reqStat7==KErrCancel);
       
  3048 
       
  3049 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3050 	fs.NotifyChange(ENotifyFile,reqStat2,path);
       
  3051 	fs.NotifyChange(ENotifyEntry,reqStat3,path);
       
  3052 	fs.NotifyChange(ENotifyAttributes,reqStat4,path);
       
  3053 
       
  3054 	test(reqStat==KRequestPending);
       
  3055 	test(reqStat2==KRequestPending);
       
  3056 	test(reqStat3==KRequestPending);
       
  3057 	test(reqStat4==KRequestPending);
       
  3058 
       
  3059 //	RFile::SetSize() of a file within the monitored directory
       
  3060 	test.Next(_L("RFile::SetSize()"));
       
  3061 	r=file.SetSize(256);
       
  3062 	test(r==KErrNone);
       
  3063 	User::WaitForRequest(reqStat);
       
  3064 	User::WaitForRequest(reqStat4);
       
  3065 	test(reqStat==KErrNone);
       
  3066 	test(reqStat2==KRequestPending);	//	Monitoring with ENotifyFile
       
  3067 	test(reqStat3==KRequestPending);	//	Monitoring with ENotifyEntry
       
  3068 	test(reqStat4==KErrNone);
       
  3069 
       
  3070 	fs.NotifyChange(ENotifyWrite,reqStat,path);
       
  3071 	test(reqStat==KRequestPending);
       
  3072 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3073 	User::WaitForRequest(reqStat4);
       
  3074 	test(reqStat4==KErrArgument);
       
  3075 	r=file.SetSize(200);
       
  3076 	test(r==KErrNone);
       
  3077 	User::After(1000000);
       
  3078 	test(reqStat==KRequestPending);		//	Monitoring with ENotifyWrite
       
  3079 
       
  3080 	file.Close();
       
  3081 	fs.NotifyChangeCancel();			//	Cancels all outstanding notification requests
       
  3082 
       
  3083 	User::WaitForRequest(reqStat);
       
  3084 	test(reqStat==KErrCancel);
       
  3085 	User::WaitForRequest(reqStat2);
       
  3086 	test(reqStat2==KErrCancel);
       
  3087 	User::WaitForRequest(reqStat3);
       
  3088 	test(reqStat3==KErrCancel);
       
  3089 
       
  3090 //	RFile::Temp() to create a temp file within the monitored directory
       
  3091 	test.Next(_L("RFile::Temp()"));
       
  3092 	path=_L("\\F32-TST\\NOTIFY\\");
       
  3093 
       
  3094 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3095 	fs.NotifyChange(ENotifyDir,reqStat2,path);
       
  3096 	fs.NotifyChange(ENotifyEntry,reqStat3,path);
       
  3097 	fs.NotifyChange(ENotifyAttributes,reqStat4,path);
       
  3098 
       
  3099 	test(reqStat==KRequestPending);
       
  3100 	test(reqStat2==KRequestPending);
       
  3101 	test(reqStat3==KRequestPending);
       
  3102 	test(reqStat4==KRequestPending);
       
  3103 
       
  3104 	TFileName fileName;
       
  3105 	r=file.Temp(TheFs,path,fileName,EFileWrite);
       
  3106 	test(r==KErrNone);
       
  3107 	User::WaitForRequest(reqStat);
       
  3108 	test(reqStat==KErrNone);
       
  3109 	test(reqStat2==KRequestPending);
       
  3110 	test(reqStat3==KRequestPending);	//	Monitoring ENotifyEntry
       
  3111 	test(reqStat4==KRequestPending);	//	Monitoring ENotifyAttributes
       
  3112 	file.Close();
       
  3113 	fs.NotifyChangeCancel();
       
  3114 
       
  3115 	User::WaitForRequest(reqStat2);
       
  3116 	test(reqStat2==KErrCancel);
       
  3117 	User::WaitForRequest(reqStat3);
       
  3118 	test(reqStat3==KErrCancel);
       
  3119 	User::WaitForRequest(reqStat4);
       
  3120 	test(reqStat4==KErrCancel);
       
  3121 
       
  3122 	fs.NotifyChange(ENotifyFile,reqStat,path);
       
  3123 	fs.NotifyChange(ENotifyDisk,reqStat2,path);
       
  3124 	fs.NotifyChange(ENotifyWrite,reqStat3,path);
       
  3125 	r=file.Temp(TheFs,path,fileName,EFileWrite);
       
  3126 	test(r==KErrNone);
       
  3127 	test(reqStat==KRequestPending);		//	Monitoring ENotifyFile
       
  3128 	test(reqStat2==KRequestPending);	//	Monitoring ENotifyDisk
       
  3129 	test(reqStat3==KRequestPending);	//	Monitoring ENotifyWrite
       
  3130 	file.Close();
       
  3131 
       
  3132 	fs.NotifyChangeCancel();	//	Cancels all outstanding notification requests
       
  3133 
       
  3134 	User::WaitForRequest(reqStat);
       
  3135 	test(reqStat==KErrCancel);
       
  3136 	User::WaitForRequest(reqStat2);
       
  3137 	test(reqStat2==KErrCancel);
       
  3138 	User::WaitForRequest(reqStat3);
       
  3139 	test(reqStat3==KErrCancel);
       
  3140 
       
  3141 //	RFile::SetModified() to change modification time of a file within monitored dir
       
  3142 	test.Next(_L("RFile::SetModified()"));
       
  3143 	path=_L("\\F32-TST\\NOTIFY\\NewFile.txt");
       
  3144 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3145 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3146 	fs.NotifyChange(ENotifyAttributes,reqStat3,path);
       
  3147 	fs.NotifyChange(ENotifyFile,reqStat4,path);
       
  3148 
       
  3149 	test(reqStat==KRequestPending);
       
  3150 	test(reqStat2==KRequestPending);
       
  3151 	test(reqStat3==KRequestPending);
       
  3152 	test(reqStat4==KRequestPending);
       
  3153 
       
  3154 	TTime now;
       
  3155 	now.HomeTime();
       
  3156 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileWrite);
       
  3157 	test(r==KErrNone);
       
  3158 	test(reqStat==KRequestPending);
       
  3159 	file.SetModified(now);
       
  3160 	file.Close();
       
  3161 	User::WaitForRequest(reqStat);
       
  3162 	test(reqStat==KErrNone);
       
  3163 	test(reqStat2==KRequestPending);
       
  3164 	User::WaitForRequest(reqStat3);
       
  3165 	test(reqStat3==KErrNone);
       
  3166 	test(reqStat4==KRequestPending);
       
  3167 	fs.NotifyChangeCancel();
       
  3168 
       
  3169 	User::WaitForRequest(reqStat2);
       
  3170 	test(reqStat2==KErrCancel);
       
  3171 	User::WaitForRequest(reqStat4);
       
  3172 	test(reqStat4==KErrCancel);
       
  3173 
       
  3174 //	RFs::SetEntry() to change a directory entry within the monitored directory
       
  3175 	test.Next(_L("RFs::SetEntry()"));
       
  3176 	TEntry entry;
       
  3177 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3178 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3179 	fs.NotifyChange(ENotifyAttributes,reqStat3,path);
       
  3180 	fs.NotifyChange(ENotifyDisk,reqStat4,path);
       
  3181 
       
  3182 	test(reqStat==KRequestPending);
       
  3183 	test(reqStat2==KRequestPending);
       
  3184 	test(reqStat3==KRequestPending);
       
  3185 	test(reqStat4==KRequestPending);
       
  3186 
       
  3187 	r=TheFs.Entry(_L("\\F32-TST\\NOTIFY\\NewFile.txt"),entry);
       
  3188 	test(reqStat==KRequestPending);
       
  3189 	now.HomeTime();
       
  3190 	r=TheFs.SetEntry(_L("\\F32-TST\\NOTIFY\\NewFile.txt"),now,KEntryAttHidden,KEntryAttNormal);
       
  3191 	test(r==KErrNone);
       
  3192 	User::WaitForRequest(reqStat);
       
  3193 	User::WaitForRequest(reqStat3);
       
  3194 	test(reqStat==KErrNone);
       
  3195 	test(reqStat2==KRequestPending);
       
  3196 	test(reqStat3==KErrNone);
       
  3197 	test(reqStat4==KRequestPending);
       
  3198 	fs.NotifyChangeCancel();
       
  3199 
       
  3200 	User::WaitForRequest(reqStat2);
       
  3201 	test(reqStat2==KErrCancel);
       
  3202 	User::WaitForRequest(reqStat4);
       
  3203 	test(reqStat4==KErrCancel);
       
  3204 
       
  3205 //	RFile::Set() to change file's modification time and attributes
       
  3206 	test.Next(_L("RFile::Set()"));
       
  3207 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3208 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3209 	fs.NotifyChange(ENotifyAttributes,reqStat3,path);
       
  3210 	fs.NotifyChange(ENotifyWrite,reqStat4,path);
       
  3211 
       
  3212 	test(reqStat==KRequestPending);
       
  3213 	test(reqStat2==KRequestPending);
       
  3214 	test(reqStat3==KRequestPending);
       
  3215 	test(reqStat4==KRequestPending);
       
  3216 
       
  3217 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileWrite);
       
  3218 	test(r==KErrNone);
       
  3219 	test(reqStat==KRequestPending);
       
  3220 	now.HomeTime();
       
  3221 	r=file.Set(now,KEntryAttNormal,KEntryAttHidden);
       
  3222 	file.Close();
       
  3223 	User::WaitForRequest(reqStat);
       
  3224 	User::WaitForRequest(reqStat3);
       
  3225 	test(reqStat==KErrNone);
       
  3226 	test(reqStat2==KRequestPending);
       
  3227 	test(reqStat3==KErrNone);
       
  3228 	test(reqStat4==KRequestPending);
       
  3229 	fs.NotifyChangeCancel();
       
  3230 
       
  3231 	User::WaitForRequest(reqStat2);
       
  3232 	test(reqStat2==KErrCancel);
       
  3233 	User::WaitForRequest(reqStat4);
       
  3234 	test(reqStat4==KErrCancel);
       
  3235 
       
  3236 //	RFs::SetDriveName()
       
  3237 
       
  3238 	test.Next(_L("RFs::SetDriveName()"));
       
  3239 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3240 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3241 	fs.NotifyChange(ENotifyDisk,reqStat3,path);
       
  3242 	fs.NotifyChange(ENotifyAttributes,reqStat4,path);
       
  3243 
       
  3244 	test(reqStat==KRequestPending);
       
  3245 	test(reqStat2==KRequestPending);
       
  3246 	test(reqStat3==KRequestPending);
       
  3247 	test(reqStat4==KRequestPending);
       
  3248 	User::After(KNotifyChangeAfter);
       
  3249 
       
  3250 	r=TheFs.SetDriveName(KDefaultDrive,_L("DRIVETEST"));
       
  3251 	test(r==KErrNone);
       
  3252 	User::WaitForRequest(reqStat);
       
  3253 	test(reqStat==KErrNone);
       
  3254 	test(reqStat2==KRequestPending);
       
  3255 	test(reqStat3==KRequestPending);
       
  3256 	test(reqStat4==KRequestPending);
       
  3257 	fs.NotifyChangeCancel();
       
  3258 
       
  3259 	User::WaitForRequest(reqStat2);
       
  3260 	test(reqStat2==KErrCancel);
       
  3261 	User::WaitForRequest(reqStat3);
       
  3262 	test(reqStat3==KErrCancel);
       
  3263 	User::WaitForRequest(reqStat4);
       
  3264 	test(reqStat4==KErrCancel);
       
  3265 
       
  3266 //	RFs::MkDir()
       
  3267 	test.Next(_L("RFs::MkDir()"));
       
  3268 	path=_L("\\F32-TST\\NOTIFY\\");
       
  3269 
       
  3270 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3271 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3272 	fs.NotifyChange(ENotifyDir,reqStat3,path);
       
  3273 	fs.NotifyChange(ENotifyFile,reqStat4,path);
       
  3274 
       
  3275 	test(reqStat==KRequestPending);
       
  3276 	test(reqStat2==KRequestPending);
       
  3277 	test(reqStat3==KRequestPending);
       
  3278 	test(reqStat4==KRequestPending);
       
  3279 
       
  3280 	r=TheFs.MkDir(_L("\\F32-TST\\NOTIFY\\EMERALD_CITY\\"));
       
  3281 	test(r==KErrNone);
       
  3282 	User::WaitForRequest(reqStat);
       
  3283 	User::WaitForRequest(reqStat2);
       
  3284 	User::WaitForRequest(reqStat3);
       
  3285 	test(reqStat==KErrNone);
       
  3286 	test(reqStat2==KErrNone);
       
  3287 	test(reqStat3==KErrNone);
       
  3288 	test(reqStat4==KRequestPending);
       
  3289 
       
  3290 //	RFs::RmDir()
       
  3291 	test.Next(_L("RFs::RmDir()"));
       
  3292 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3293 	fs.NotifyChange(ENotifyDir,reqStat2,path);
       
  3294 	fs.NotifyChange(ENotifyWrite,reqStat3,path);
       
  3295 
       
  3296 	test(reqStat==KRequestPending);
       
  3297 	test(reqStat2==KRequestPending);
       
  3298 	test(reqStat3==KRequestPending);
       
  3299 
       
  3300 	r=TheFs.RmDir(_L("\\F32-TST\\NOTIFY\\EMERALD_CITY\\"));
       
  3301 	test(r==KErrNone);
       
  3302 	User::WaitForRequest(reqStat);
       
  3303 	User::WaitForRequest(reqStat2);
       
  3304 	test(reqStat==KErrNone);
       
  3305 	test(reqStat2==KErrNone);
       
  3306 	test(reqStat3==KRequestPending);
       
  3307 	test(reqStat4==KRequestPending);
       
  3308 	fs.NotifyChangeCancel();
       
  3309 
       
  3310 	User::WaitForRequest(reqStat3);
       
  3311 	test(reqStat3==KErrCancel);
       
  3312 	User::WaitForRequest(reqStat4);
       
  3313 	test(reqStat4==KErrCancel);
       
  3314 
       
  3315 //	RFile::Create()
       
  3316 	test.Next(_L("RFile::Create()"));
       
  3317 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3318 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3319 	fs.NotifyChange(ENotifyDir,reqStat3,path);
       
  3320 	fs.NotifyChange(ENotifyFile,reqStat4,path);
       
  3321 
       
  3322 	test(reqStat==KRequestPending);
       
  3323 	test(reqStat2==KRequestPending);
       
  3324 	test(reqStat3==KRequestPending);
       
  3325 	test(reqStat4==KRequestPending);
       
  3326 
       
  3327 	r=file.Create(TheFs,_L("\\F32-TST\\NOTIFY\\Good_Witch.bat"),EFileRead|EFileWrite);
       
  3328 	test(r==KErrNone);
       
  3329 	User::WaitForRequest(reqStat);
       
  3330 	User::WaitForRequest(reqStat2);
       
  3331 	User::WaitForRequest(reqStat4);
       
  3332 	test(reqStat==KErrNone);
       
  3333 	test(reqStat2==KErrNone);
       
  3334 	test(reqStat3==KRequestPending);	//	Monitoring ENotifyDir
       
  3335 	test(reqStat4==KErrNone);
       
  3336 	file.Close();
       
  3337 	fs.NotifyChangeCancel(reqStat3);
       
  3338 	User::WaitForRequest(reqStat3);
       
  3339 
       
  3340 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3341 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3342 	fs.NotifyChange(ENotifyDisk,reqStat3,path);
       
  3343 	fs.NotifyChange(ENotifyWrite,reqStat4,path);
       
  3344 
       
  3345 	test(reqStat==KRequestPending);
       
  3346 	test(reqStat2==KRequestPending);
       
  3347 	test(reqStat3==KRequestPending);
       
  3348 	test(reqStat4==KRequestPending);
       
  3349 
       
  3350 	r=file.Create(TheFs,_L("\\F32-TST\\NOTIFY\\Bad_Witch.bat"),EFileRead|EFileWrite);
       
  3351 	test(r==KErrNone);
       
  3352 	User::WaitForRequest(reqStat);
       
  3353 	User::WaitForRequest(reqStat2);
       
  3354 	test(reqStat==KErrNone);
       
  3355 	test(reqStat2==KErrNone);
       
  3356 	test(reqStat3==KRequestPending);
       
  3357 	test(reqStat4==KRequestPending);
       
  3358 	file.Close();
       
  3359 	fs.NotifyChangeCancel();
       
  3360 
       
  3361 	User::WaitForRequest(reqStat3);
       
  3362 	test(reqStat3==KErrCancel);
       
  3363 	User::WaitForRequest(reqStat4);
       
  3364 	test(reqStat4==KErrCancel);
       
  3365 
       
  3366 //	RFs::Delete()
       
  3367 	test.Next(_L("RFs::Delete()"));
       
  3368 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3369 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3370 	fs.NotifyChange(ENotifyDir,reqStat3,path);
       
  3371 	fs.NotifyChange(ENotifyFile,reqStat4,path);
       
  3372 
       
  3373 	test(reqStat==KRequestPending);
       
  3374 	test(reqStat2==KRequestPending);
       
  3375 	test(reqStat3==KRequestPending);
       
  3376 	test(reqStat4==KRequestPending);
       
  3377 
       
  3378 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\Good_Witch.bat"));
       
  3379 	test(r==KErrNone);
       
  3380 	User::WaitForRequest(reqStat);
       
  3381 	User::WaitForRequest(reqStat2);
       
  3382 	User::WaitForRequest(reqStat4);
       
  3383 	test(reqStat==KErrNone);
       
  3384 	test(reqStat2==KErrNone);
       
  3385 	test(reqStat3==KRequestPending);	//	Monitoring ENotifyDir
       
  3386 	test(reqStat4==KErrNone);
       
  3387 	fs.NotifyChangeCancel(reqStat3);
       
  3388 	User::WaitForRequest(reqStat3);
       
  3389 	test(reqStat3==KErrCancel);
       
  3390 
       
  3391 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3392 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3393 	fs.NotifyChange(ENotifyAttributes,reqStat3,path);
       
  3394 	fs.NotifyChange(ENotifyAll,reqStat4,path);
       
  3395 
       
  3396 	test(reqStat==KRequestPending);
       
  3397 	test(reqStat2==KRequestPending);
       
  3398 	test(reqStat3==KRequestPending);
       
  3399 	test(reqStat4==KRequestPending);
       
  3400 
       
  3401 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\Bad_Witch.bat"));
       
  3402 	test(r==KErrNone);
       
  3403 	User::WaitForRequest(reqStat);
       
  3404 	User::WaitForRequest(reqStat2);
       
  3405 	User::WaitForRequest(reqStat4);
       
  3406 	test(reqStat==KErrNone);
       
  3407 	test(reqStat2==KErrNone);
       
  3408 	test(reqStat3==KRequestPending);
       
  3409 	test(reqStat4==KErrNone);
       
  3410 	fs.NotifyChangeCancel(reqStat3);
       
  3411 	User::WaitForRequest(reqStat3);
       
  3412 	test(reqStat3==KErrCancel);
       
  3413 
       
  3414 //	RFile::Replace()
       
  3415 	test.Next(_L("RFile::Replace()"));
       
  3416 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3417 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3418 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3419 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3420 
       
  3421 	test(reqStat==KRequestPending);
       
  3422 	test(reqStat2==KRequestPending);
       
  3423 	test(reqStat3==KRequestPending);
       
  3424 	test(reqStat4==KRequestPending);
       
  3425 
       
  3426 	r=file.Replace(TheFs,_L("\\F32-TST\\NOTIFY\\Good_Witch.bat"),EFileRead|EFileWrite);
       
  3427 	test(r==KErrNone);
       
  3428 	User::WaitForRequest(reqStat);
       
  3429 	User::WaitForRequest(reqStat2);
       
  3430 	User::WaitForRequest(reqStat3);
       
  3431 	test(reqStat==KErrNone);
       
  3432 	test(reqStat2==KErrNone);
       
  3433 	test(reqStat3==KErrNone);
       
  3434 	test(reqStat4==KRequestPending);
       
  3435 	file.Close();
       
  3436 	fs.NotifyChangeCancel();
       
  3437 
       
  3438 	test(reqStat==KErrNone);
       
  3439 	test(reqStat2==KErrNone);
       
  3440 	test(reqStat3==KErrNone);
       
  3441 	User::WaitForRequest(reqStat4);
       
  3442 	test(reqStat4==KErrCancel);
       
  3443 
       
  3444 //	RFs::Delete()
       
  3445 	test.Next(_L("RFs::Delete()"));
       
  3446 	path=_L("\\F32-TST\\NOTIFY\\Good_Witch.bat");
       
  3447 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3448 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3449 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3450 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3451 
       
  3452 	test(reqStat==KRequestPending);
       
  3453 	test(reqStat2==KRequestPending);
       
  3454 	test(reqStat3==KRequestPending);
       
  3455 	User::WaitForRequest(reqStat4);
       
  3456 	test(reqStat4==KErrArgument);
       
  3457 
       
  3458 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\Good_Witch.bat"));
       
  3459 	test(r==KErrNone);
       
  3460 	User::WaitForRequest(reqStat);
       
  3461 	User::WaitForRequest(reqStat2);
       
  3462 	User::WaitForRequest(reqStat3);
       
  3463 	test(reqStat==KErrNone);
       
  3464 	test(reqStat2==KErrNone);
       
  3465 	test(reqStat3==KErrNone);
       
  3466 	test(reqStat4==KErrArgument);
       
  3467 
       
  3468 //	RFs::SetVolumeLabel()
       
  3469 	test.Next(_L("RFs::SetVolumeLabel()"));
       
  3470 	path=_L("\\F32-TST\\NOTIFY\\");
       
  3471 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3472 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3473 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3474 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3475 	fs.NotifyChange(ENotifyWrite,reqStat5,path);
       
  3476 	fs.NotifyChange(ENotifyAttributes,reqStat6,path);
       
  3477 	fs.NotifyChange(ENotifyDisk,reqStat7,path);
       
  3478 
       
  3479 	test(reqStat==KRequestPending);
       
  3480 	test(reqStat2==KRequestPending);
       
  3481 	test(reqStat3==KRequestPending);
       
  3482 	test(reqStat4==KRequestPending);
       
  3483 	test(reqStat5==KRequestPending);
       
  3484 	test(reqStat6==KRequestPending);
       
  3485 	test(reqStat7==KRequestPending);
       
  3486 
       
  3487 	TInt driveNum=CurrentDrive();
       
  3488 	TVolumeInfo volInfo;
       
  3489 	TFileName currentVolName;
       
  3490 	r=TheFs.Volume(volInfo,driveNum);
       
  3491 	test(r==KErrNone);
       
  3492 	test(reqStat==KRequestPending);
       
  3493 	currentVolName=volInfo.iName;
       
  3494 
       
  3495 	r=TheFs.SetVolumeLabel(_L("VOL"),driveNum);
       
  3496 	if (r==KErrNone)
       
  3497 		{
       
  3498 		User::WaitForRequest(reqStat);
       
  3499 		User::WaitForRequest(reqStat2);
       
  3500 		User::WaitForRequest(reqStat7);
       
  3501 
       
  3502 		test(reqStat==KErrNone);
       
  3503 		test(reqStat2==KErrNone);
       
  3504 		test(reqStat3==KRequestPending);
       
  3505 		test(reqStat4==KRequestPending);
       
  3506 		test(reqStat5==KRequestPending);
       
  3507 		test(reqStat6==KRequestPending);
       
  3508 		test(reqStat7==KErrNone);
       
  3509 
       
  3510 		fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3511 		fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3512 		fs.NotifyChange(ENotifyDisk,reqStat7,path);
       
  3513 
       
  3514 		test(reqStat==KRequestPending);
       
  3515 		test(reqStat2==KRequestPending);
       
  3516 		test(reqStat7==KRequestPending);
       
  3517 
       
  3518 		r=TheFs.SetVolumeLabel(currentVolName,driveNum);
       
  3519 		test(r==KErrNone);
       
  3520 
       
  3521 		User::WaitForRequest(reqStat);
       
  3522 		User::WaitForRequest(reqStat2);
       
  3523 		User::WaitForRequest(reqStat7);
       
  3524 
       
  3525 		test(reqStat==KErrNone);
       
  3526 		test(reqStat2==KErrNone);
       
  3527 		test(reqStat3==KRequestPending);
       
  3528 		test(reqStat4==KRequestPending);
       
  3529 		test(reqStat5==KRequestPending);
       
  3530 		test(reqStat6==KRequestPending);
       
  3531 		test(reqStat7==KErrNone);
       
  3532 
       
  3533 		r=TheFs.Volume(volInfo,driveNum);
       
  3534 		test(r==KErrNone);
       
  3535 		test(volInfo.iName==currentVolName);
       
  3536 
       
  3537 		fs.NotifyChangeCancel();
       
  3538 
       
  3539 		User::WaitForRequest(reqStat3);
       
  3540 		test(reqStat3==KErrCancel);
       
  3541 		User::WaitForRequest(reqStat4);
       
  3542 		test(reqStat4==KErrCancel);
       
  3543 		User::WaitForRequest(reqStat5);
       
  3544 		test(reqStat5==KErrCancel);
       
  3545 		User::WaitForRequest(reqStat6);
       
  3546 		test(reqStat6==KErrCancel);
       
  3547 		}
       
  3548 
       
  3549 	else	//	RFs::SetVolumeLabel() doesn't work on subst drives
       
  3550 		{
       
  3551 		fs.NotifyChangeCancel();
       
  3552 		User::WaitForRequest(reqStat);
       
  3553 		User::WaitForRequest(reqStat2);
       
  3554 		User::WaitForRequest(reqStat3);
       
  3555 		User::WaitForRequest(reqStat4);
       
  3556 		User::WaitForRequest(reqStat5);
       
  3557 		User::WaitForRequest(reqStat6);
       
  3558 		User::WaitForRequest(reqStat7);
       
  3559 		test.Printf(_L("Cannot set volume label on a substed drive!\n"));
       
  3560 		}
       
  3561 
       
  3562 
       
  3563 //	RFile::Rename()
       
  3564 	test.Next(_L("RFile::Rename()"));
       
  3565 	path=_L("\\F32-TST\\NOTIFY\\");
       
  3566 
       
  3567 	file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileShareExclusive|EFileWrite);
       
  3568 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3569 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3570 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3571 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3572 
       
  3573 	test(reqStat==KRequestPending);
       
  3574 	test(reqStat2==KRequestPending);
       
  3575 	test(reqStat3==KRequestPending);
       
  3576 	test(reqStat4==KRequestPending);
       
  3577 
       
  3578 	r=file.Rename(_L("\\F32-TST\\NOTIFY\\OldFile.abc"));
       
  3579 	test(r==KErrNone||r==KErrAlreadyExists);
       
  3580 	User::WaitForRequest(reqStat);
       
  3581 	User::WaitForRequest(reqStat2);
       
  3582 	User::WaitForRequest(reqStat3);
       
  3583 	test(reqStat==KErrNone);
       
  3584 	test(reqStat2==KErrNone);
       
  3585 	test(reqStat3==KErrNone);
       
  3586 	test(reqStat4==KRequestPending);	//	Monitoring ENotifyDir
       
  3587 	file.Close();
       
  3588 	fs.NotifyChangeCancel();
       
  3589 	User::WaitForRequest(reqStat4);
       
  3590 	test(reqStat4==KErrCancel);
       
  3591 
       
  3592 	path=_L("\\F32-TST\\NOTIFY\\OldFile.abc");
       
  3593 
       
  3594 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\OldFile.abc"),EFileShareExclusive|EFileWrite);
       
  3595 	test(r==KErrNone);
       
  3596 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3597 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3598 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3599 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3600 
       
  3601 	test(reqStat==KRequestPending);
       
  3602 	test(reqStat2==KRequestPending);
       
  3603 	test(reqStat3==KRequestPending);
       
  3604 	User::WaitForRequest(reqStat4);
       
  3605 	test(reqStat4==KErrArgument);
       
  3606 
       
  3607 	r=file.Rename(_L("\\F32-TST\\NOTIFY\\NewFile.xyz"));
       
  3608 	test(r==KErrNone);
       
  3609 	User::WaitForRequest(reqStat);
       
  3610 	User::WaitForRequest(reqStat2);
       
  3611 	User::WaitForRequest(reqStat3);
       
  3612 	test(reqStat==KErrNone);
       
  3613 	test(reqStat2==KErrNone);
       
  3614 	test(reqStat3==KErrNone);
       
  3615 	test(reqStat4==KErrArgument);
       
  3616 	file.Close();
       
  3617 
       
  3618 //	RFs::Rename()
       
  3619 	test.Next(_L("RFs::Rename()"));
       
  3620 	path=_L("\\F32-TST\\NOTIFY\\");
       
  3621 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3622 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3623 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3624 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3625 
       
  3626 	test(reqStat==KRequestPending);
       
  3627 	test(reqStat2==KRequestPending);
       
  3628 	test(reqStat3==KRequestPending);
       
  3629 	test(reqStat4==KRequestPending);
       
  3630 
       
  3631 	r=TheFs.Rename(_L("\\F32-TST\\NOTIFY\\NewFile.xyz"),_L("\\F32-TST\\NOTIFY\\NewerFile.cat"));
       
  3632 	test(r==KErrNone);
       
  3633 	User::WaitForRequest(reqStat);
       
  3634 	User::WaitForRequest(reqStat2);
       
  3635 	User::WaitForRequest(reqStat3);
       
  3636 	test(reqStat==KErrNone);
       
  3637 	test(reqStat2==KErrNone);
       
  3638 	test(reqStat3==KErrNone);
       
  3639 	test(reqStat4==KRequestPending);	//	Changed a file not a directory entry
       
  3640 	fs.NotifyChangeCancel();
       
  3641 
       
  3642 	test(reqStat==KErrNone);
       
  3643 	test(reqStat2==KErrNone);
       
  3644 	test(reqStat3==KErrNone);
       
  3645 	User::WaitForRequest(reqStat4);
       
  3646 	test(reqStat4==KErrCancel);
       
  3647 
       
  3648 	path=_L("\\F32-TST\\NOTIFY\\NewerFile.cat");
       
  3649 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3650 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3651 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3652 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3653 
       
  3654 	test(reqStat==KRequestPending);
       
  3655 	test(reqStat2==KRequestPending);
       
  3656 	test(reqStat3==KRequestPending);
       
  3657 	User::WaitForRequest(reqStat4);
       
  3658 	test(reqStat4==KErrArgument);
       
  3659 
       
  3660 	r=TheFs.Rename(_L("\\F32-TST\\NOTIFY\\NewerFile.cat"),_L("\\F32-TST\\NOTIFY\\Original.dog"));
       
  3661 	test(r==KErrNone);
       
  3662 	User::WaitForRequest(reqStat);
       
  3663 	User::WaitForRequest(reqStat2);
       
  3664 	User::WaitForRequest(reqStat3);
       
  3665 	test(reqStat==KErrNone);
       
  3666 	test(reqStat2==KErrNone);
       
  3667 	test(reqStat3==KErrNone);
       
  3668 
       
  3669 	path=_L("\\F32-TST\\NOTIFY\\");
       
  3670 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3671 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3672 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3673 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3674 
       
  3675 	test(reqStat==KRequestPending);
       
  3676 	test(reqStat2==KRequestPending);
       
  3677 	test(reqStat3==KRequestPending);
       
  3678 	test(reqStat4==KRequestPending);
       
  3679 
       
  3680 	r=TheFs.Rename(_L("\\F32-TST\\NOTIFY\\"),_L("\\F32-TST\\NOTIFY_TEMP\\"));
       
  3681 	test(r==KErrNone);
       
  3682 	User::WaitForRequest(reqStat);
       
  3683 	User::WaitForRequest(reqStat2);
       
  3684 	User::WaitForRequest(reqStat3);
       
  3685 	User::WaitForRequest(reqStat4);
       
  3686 	test(reqStat==KErrNone);
       
  3687 	test(reqStat2==KErrNone);
       
  3688 	test(reqStat3==KErrNone);	//	Changed a directory entry but notified anyway despite
       
  3689 	test(reqStat4==KErrNone);	//	requesting file notification only because the path we
       
  3690 								//	were monitoring has changed
       
  3691 
       
  3692 	path=_L("\\F32-TST\\NOTIFY_TEMP\\Original.dog");
       
  3693 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3694 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3695 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3696 	fs.NotifyChange(ENotifyDir,reqStat4,path);
       
  3697 
       
  3698 	test(reqStat==KRequestPending);
       
  3699 	test(reqStat2==KRequestPending);
       
  3700 	test(reqStat3==KRequestPending);
       
  3701 	User::WaitForRequest(reqStat4);
       
  3702 	test(reqStat4==KErrArgument);
       
  3703 
       
  3704 	r=TheFs.Rename(_L("\\F32-TST\\NOTIFY_TEMP\\"),_L("\\F32-TST\\NOTIFY\\"));
       
  3705 	test(r==KErrNone);
       
  3706 	User::WaitForRequest(reqStat);
       
  3707 	User::WaitForRequest(reqStat2);
       
  3708 	User::WaitForRequest(reqStat3);
       
  3709 	test(reqStat==KErrNone);			//	Modified a directory above the level at which we
       
  3710 	test(reqStat2==KErrNone);			//	are monitoring for changes - we must be notified
       
  3711 	test(reqStat3==KErrNone);			//	anyway because the path has changed
       
  3712 
       
  3713 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3714 	test(reqStat==KRequestPending);
       
  3715 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3716 	test(reqStat2==KRequestPending);
       
  3717 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3718 	test(reqStat3==KRequestPending);
       
  3719 
       
  3720 	fs.NotifyChangeCancel(reqStat);
       
  3721 	User::WaitForRequest(reqStat);
       
  3722 	test(reqStat==KErrCancel);
       
  3723 	fs.NotifyChangeCancel(reqStat2);
       
  3724 	User::WaitForRequest(reqStat2);
       
  3725 	test(reqStat2==KErrCancel);
       
  3726 	fs.NotifyChangeCancel(reqStat3);
       
  3727 	User::WaitForRequest(reqStat3);
       
  3728 	test(reqStat3==KErrCancel);
       
  3729 
       
  3730 	path=_L("\\F32-TST\\NOTIFY\\Original.dog");
       
  3731 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3732 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3733 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3734 
       
  3735 	test(reqStat==KRequestPending);
       
  3736 	test(reqStat2==KRequestPending);
       
  3737 	test(reqStat3==KRequestPending);
       
  3738 
       
  3739 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\Original.dog"));
       
  3740 	test(r==KErrNone);
       
  3741 	User::WaitForRequest(reqStat);
       
  3742 	User::WaitForRequest(reqStat2);
       
  3743 	User::WaitForRequest(reqStat3);
       
  3744 	test(reqStat==KErrNone);
       
  3745 	test(reqStat2==KErrNone);
       
  3746 	test(reqStat3==KErrNone);
       
  3747 
       
  3748 	path=_L("\\F32-TST\\NOTIFY\\");
       
  3749 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3750 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3751 	fs.NotifyChange(ENotifyDir,reqStat3,path);
       
  3752 
       
  3753 	test(reqStat==KRequestPending);
       
  3754 	test(reqStat2==KRequestPending);
       
  3755 	test(reqStat3==KRequestPending);
       
  3756 
       
  3757 	r=TheFs.Rename(_L("\\F32-TST\\"),_L("\\F32-TEST\\"));
       
  3758 	test(r==KErrNone);
       
  3759 	User::WaitForRequest(reqStat);
       
  3760 	User::WaitForRequest(reqStat2);
       
  3761 	User::WaitForRequest(reqStat3);
       
  3762 	test(reqStat==KErrNone);			//	Modified a directory above the level at which we
       
  3763 	test(reqStat2==KErrNone);			//	are monitoring for changes but we receive notification
       
  3764 	test(reqStat3==KErrNone);			//	because the notification path has been changed
       
  3765 
       
  3766 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3767 	//	Notification request is submitted, despite the subject's disappearance
       
  3768 	test(reqStat==KRequestPending);
       
  3769 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3770 	//	Notification request is submitted, despite the subject's disappearance
       
  3771 	test(reqStat2==KRequestPending);
       
  3772 	fs.NotifyChange(ENotifyFile,reqStat3,path);
       
  3773 	//	Notification request is submitted, despite the subject's disappearance
       
  3774 	test(reqStat3==KRequestPending);
       
  3775 
       
  3776 	fs.NotifyChangeCancel(reqStat);
       
  3777 	User::WaitForRequest(reqStat);
       
  3778 	test(reqStat==KErrCancel);
       
  3779 	fs.NotifyChangeCancel(reqStat2);
       
  3780 	User::WaitForRequest(reqStat2);
       
  3781 	test(reqStat2==KErrCancel);
       
  3782 	fs.NotifyChangeCancel(reqStat3);
       
  3783 	User::WaitForRequest(reqStat3);
       
  3784 	test(reqStat3==KErrCancel);
       
  3785 
       
  3786 	path=_L("\\F32-TEST\\NOTIFY\\");
       
  3787 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3788 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3789 	fs.NotifyChange(ENotifyDir,reqStat3,path);
       
  3790 
       
  3791 	test(reqStat==KRequestPending);
       
  3792 	test(reqStat2==KRequestPending);
       
  3793 	test(reqStat3==KRequestPending);
       
  3794 
       
  3795 	r=TheFs.Rename(_L("\\F32-TEST\\NOTIFY\\"),_L("\\F32-TEST\\NOTIFY_CHANGED\\"));
       
  3796 	test(r==KErrNone);
       
  3797 
       
  3798 	User::WaitForRequest(reqStat);
       
  3799 	User::WaitForRequest(reqStat2);
       
  3800 	User::WaitForRequest(reqStat3);
       
  3801 
       
  3802 	test(reqStat==KErrNone);			//	Rename the directory we were monitoring
       
  3803 	test(reqStat2==KErrNone);
       
  3804 	test(reqStat3==KErrNone);
       
  3805 
       
  3806 //	Tidy up the test directory before continuing (while testing notifications of renaming to the monitored directory)
       
  3807 
       
  3808 	path=_L("\\F32-TST\\NOTIFY_CHANGED\\");
       
  3809 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3810 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3811 	fs.NotifyChange(ENotifyDir,reqStat3,path);
       
  3812 	fs.NotifyChange(ENotifyFile,reqStat4,path);
       
  3813 
       
  3814 	test(reqStat==KRequestPending);
       
  3815 	test(reqStat2==KRequestPending);
       
  3816 	test(reqStat3==KRequestPending);
       
  3817 	test(reqStat4==KRequestPending);
       
  3818 
       
  3819 	r=TheFs.Rename(_L("\\F32-TEST\\"),_L("\\F32-TST\\"));
       
  3820 	test(r==KErrNone);
       
  3821 
       
  3822 	User::WaitForRequest(reqStat);
       
  3823 	User::WaitForRequest(reqStat2);
       
  3824 	User::WaitForRequest(reqStat3);
       
  3825 
       
  3826 	test(reqStat==KErrNone);			//	Renaming to (under) the directory we were monitoring
       
  3827 	test(reqStat2==KErrNone);
       
  3828 	test(reqStat3==KErrNone);
       
  3829 	test(reqStat4==KRequestPending);
       
  3830 
       
  3831 	fs.NotifyChangeCancel(reqStat4);
       
  3832 	User::WaitForRequest(reqStat4);
       
  3833 	test(reqStat4==KErrCancel);
       
  3834 
       
  3835 	path=_L("\\F32-TST\\NOTIFY\\");
       
  3836 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3837 	fs.NotifyChange(ENotifyEntry,reqStat2,path);
       
  3838 	fs.NotifyChange(ENotifyDir,reqStat3,path);
       
  3839 	fs.NotifyChange(ENotifyFile,reqStat4,path);
       
  3840 
       
  3841 	test(reqStat==KRequestPending);
       
  3842 	test(reqStat2==KRequestPending);
       
  3843 	test(reqStat3==KRequestPending);
       
  3844 	test(reqStat4==KRequestPending);
       
  3845 
       
  3846 	r=TheFs.Rename(_L("\\F32-TST\\NOTIFY_CHANGED\\"),_L("\\F32-TST\\NOTIFY\\"));
       
  3847 	test(r==KErrNone);
       
  3848 
       
  3849 	User::WaitForRequest(reqStat);
       
  3850 	User::WaitForRequest(reqStat2);
       
  3851 	User::WaitForRequest(reqStat3);
       
  3852 
       
  3853 	test(reqStat==KErrNone);			//	Renaming to the directory we were monitoring
       
  3854 	test(reqStat2==KErrNone);
       
  3855 	test(reqStat3==KErrNone);
       
  3856 	test(reqStat4==KRequestPending);
       
  3857 
       
  3858 	fs.NotifyChangeCancel(reqStat4);
       
  3859 	User::WaitForRequest(reqStat4);
       
  3860 	test(reqStat4==KErrCancel);
       
  3861 
       
  3862 //	Test combinations of notify types
       
  3863 	test.Next(_L("Test combinations of notify types"));
       
  3864 
       
  3865 	path=_L("\\F32-TST\\NOTIFY\\");
       
  3866 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3867 	fs.NotifyChange((TNotifyType)(KGenericEntryChange|ENotifyAttributes),reqStat2,path);
       
  3868 	fs.NotifyChange((TNotifyType)(ENotifyDir|ENotifyFile),reqStat3,path);
       
  3869 	fs.NotifyChange((TNotifyType)(ENotifyDisk|ENotifyAttributes),reqStat4,path);
       
  3870 
       
  3871 	test(reqStat==KRequestPending);
       
  3872 	test(reqStat2==KRequestPending);
       
  3873 	test(reqStat3==KRequestPending);
       
  3874 	test(reqStat4==KRequestPending);
       
  3875 
       
  3876 	r=file.Create(TheFs,_L("\\F32-TST\\NOTIFY\\Munchkin.msg"),EFileRead|EFileWrite);
       
  3877 	test(r==KErrNone);
       
  3878 	User::WaitForRequest(reqStat);
       
  3879 	User::WaitForRequest(reqStat2);
       
  3880 	User::WaitForRequest(reqStat3);
       
  3881 	test(reqStat==KErrNone);
       
  3882 	test(reqStat2==KErrNone);
       
  3883 	test(reqStat3==KErrNone);
       
  3884 	test(reqStat4==KRequestPending);	//	Monitoring ENotifyAttributes|ENotifyDisk
       
  3885 	file.Close();
       
  3886 	fs.NotifyChangeCancel(reqStat4);
       
  3887 	User::WaitForRequest(reqStat4);
       
  3888 	test(reqStat4==KErrCancel);
       
  3889 
       
  3890 //	RFile::SetModified()
       
  3891 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3892 	fs.NotifyChange((TNotifyType)(KGenericEntryChange|ENotifyAttributes),reqStat2,path);
       
  3893 	fs.NotifyChange((TNotifyType)(ENotifyDir|ENotifyFile),reqStat3,path);
       
  3894 	fs.NotifyChange((TNotifyType)(ENotifyDisk|ENotifyAttributes),reqStat4,path);
       
  3895 
       
  3896 	test(reqStat==KRequestPending);
       
  3897 	test(reqStat2==KRequestPending);
       
  3898 	test(reqStat3==KRequestPending);
       
  3899 	test(reqStat4==KRequestPending);
       
  3900 
       
  3901 	TTime nowTime;
       
  3902 	nowTime.HomeTime();
       
  3903 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\Munchkin.msg"),EFileRead|EFileWrite);
       
  3904 	test(r==KErrNone);
       
  3905 	test(reqStat==KRequestPending);
       
  3906 	file.SetModified(now);
       
  3907 	file.Close();
       
  3908 	User::WaitForRequest(reqStat);
       
  3909 	User::WaitForRequest(reqStat2);
       
  3910 	User::WaitForRequest(reqStat4);
       
  3911 	test(reqStat==KErrNone);
       
  3912 	test(reqStat2==KErrNone);
       
  3913 	test(reqStat3==KRequestPending);
       
  3914 	test(reqStat4==KErrNone);
       
  3915 	fs.NotifyChangeCancel();
       
  3916 	User::WaitForRequest(reqStat3);
       
  3917 	test(reqStat3==KErrCancel);
       
  3918 
       
  3919 //	RFile::Write()
       
  3920 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3921 	fs.NotifyChange((TNotifyType)(KGenericEntryChange|ENotifyAttributes),reqStat2,path);
       
  3922 	fs.NotifyChange((TNotifyType)(ENotifyFile|ENotifyWrite),reqStat3,path);
       
  3923 	fs.NotifyChange((TNotifyType)(ENotifyDir|ENotifyWrite),reqStat4,path);
       
  3924 
       
  3925 	test(reqStat==KRequestPending);
       
  3926 	test(reqStat2==KRequestPending);
       
  3927 	test(reqStat3==KRequestPending);
       
  3928 	test(reqStat4==KRequestPending);
       
  3929 
       
  3930 	r=file.Open(TheFs,_L("\\F32-TST\\NOTIFY\\Munchkin.msg"),EFileRead|EFileWrite);
       
  3931 	test(r==KErrNone);
       
  3932 	r=file.Write(0,_L8("Pay no attention to the man behind the curtain"));
       
  3933 	file.Close();
       
  3934 	User::WaitForRequest(reqStat);
       
  3935 	User::WaitForRequest(reqStat3);
       
  3936 	User::WaitForRequest(reqStat4);
       
  3937 	test(reqStat==KErrNone);
       
  3938 	test(reqStat2==KRequestPending);
       
  3939 	test(reqStat3==KErrNone);
       
  3940 	test(reqStat4==KErrNone);
       
  3941 	fs.NotifyChangeCancel(reqStat2);	//	Cancels all outstanding notification requests
       
  3942 	User::WaitForRequest(reqStat2);
       
  3943 	test(reqStat2==KErrCancel);
       
  3944 
       
  3945 //	RFs::Delete()
       
  3946 	test.Next(_L("RFs::Delete()"));
       
  3947 	fs.NotifyChange(ENotifyAll,reqStat,path);
       
  3948 	fs.NotifyChange((TNotifyType)(KGenericEntryChange|ENotifyAttributes),reqStat2,path);
       
  3949 	fs.NotifyChange((TNotifyType)(ENotifyFile|ENotifyWrite),reqStat3,path);
       
  3950 	fs.NotifyChange((TNotifyType)(ENotifyDir|ENotifyWrite),reqStat4,path);
       
  3951 
       
  3952 	test(reqStat==KRequestPending);
       
  3953 	test(reqStat2==KRequestPending);
       
  3954 	test(reqStat3==KRequestPending);
       
  3955 	test(reqStat4==KRequestPending);
       
  3956 
       
  3957 	r=TheFs.Delete(_L("\\F32-TST\\NOTIFY\\Munchkin.msg"));
       
  3958 	test(r==KErrNone);
       
  3959 	User::WaitForRequest(reqStat);
       
  3960 	User::WaitForRequest(reqStat2);
       
  3961 	User::WaitForRequest(reqStat3);
       
  3962 	test(reqStat==KErrNone);
       
  3963 	test(reqStat2==KErrNone);
       
  3964 	test(reqStat3==KErrNone);
       
  3965 	test(reqStat4==KRequestPending);
       
  3966 	fs.NotifyChangeCancel(reqStat4);
       
  3967 	User::WaitForRequest(reqStat4);
       
  3968 	test(reqStat4==KErrCancel);
       
  3969 
       
  3970 	fs.Close();
       
  3971 	}
       
  3972 
       
  3973 #if defined __EPOC32__ && defined __INCLUDE_MANUAL_TESTS__
       
  3974 // Manual media change test
       
  3975 // assumes the media is intially present and then prompts
       
  3976 // the user to remove the media
       
  3977 static void Test99()
       
  3978 	{
       
  3979 	TBuf<64> b;
       
  3980 	b.Format(_L("Test Manual Media change notification (socket:%d)"),gSocketNumber);
       
  3981 	test.Next(b);
       
  3982 	TRequestStatus reqStat=0;
       
  3983 
       
  3984 	RFs fs;
       
  3985 	TInt r=fs.Connect();
       
  3986 	test(r==KErrNone);
       
  3987 
       
  3988 	TDriveInfo driveInfo;
       
  3989 	TInt driveNum = EDriveC + SocketToDrive[gSocketNumber];
       
  3990 
       
  3991 	// verify TDriveInfo.iType == EMediaHardDisk
       
  3992 	r = fs.Drive(driveInfo, driveNum);
       
  3993 	test (r == KErrNone);
       
  3994 	test.Printf(_L("iType = %d\n"), driveInfo.iType);
       
  3995 	test(driveInfo.iType == EMediaHardDisk);
       
  3996 
       
  3997 
       
  3998 	// ask the user to eject the media
       
  3999 	TheFs.NotifyChange(ENotifyEntry,reqStat);
       
  4000 	test(reqStat==KRequestPending);
       
  4001 	test.Printf(_L("Please eject media on drive %C...\n"), 'A' + driveNum);
       
  4002 	User::WaitForRequest(reqStat);
       
  4003 	test.Printf(_L("Done.\n"));
       
  4004 	TInt reqInt=reqStat.Int();
       
  4005 	test(reqInt==KErrNone);
       
  4006 	User::WaitForRequest(reqStat);
       
  4007 
       
  4008 	// verify TDriveInfo.iType == EMediaNotPresent
       
  4009 	r = fs.Drive(driveInfo, driveNum);
       
  4010 	test (r == KErrNone);
       
  4011 	test.Printf(_L("iType = %d\n"), driveInfo.iType);
       
  4012 	test(driveInfo.iType == EMediaNotPresent);
       
  4013 
       
  4014 
       
  4015 	// ask the user to re-insert the media
       
  4016 	TheFs.NotifyChange(ENotifyEntry,reqStat);
       
  4017 	test(reqStat==KRequestPending);
       
  4018 	test.Printf(_L("Please re-insert media...\n"));
       
  4019 	User::WaitForRequest(reqStat);
       
  4020 	test.Printf(_L("Done.\n"));
       
  4021 	reqInt = reqStat.Int();
       
  4022 	test(reqInt==KErrNone);
       
  4023 	User::WaitForRequest(reqStat);
       
  4024 
       
  4025 	// verify TDriveInfo.iType == EMediaHardDisk
       
  4026 	r = fs.Drive(driveInfo, driveNum);
       
  4027 	test (r == KErrNone);
       
  4028 	test.Printf(_L("iType = %d\n"), driveInfo.iType);
       
  4029 	test(driveInfo.iType == EMediaHardDisk);
       
  4030 
       
  4031 	fs.Close();
       
  4032 	}
       
  4033 #endif	// __INCLUDE_MANUAL_TESTS__
       
  4034 
       
  4035 
       
  4036 //---------------------------------------------
       
  4037 //! @SYMTestCaseID PBASE-T_NOTIFY-0042
       
  4038 //! @SYMTestType UT
       
  4039 //! @SYMREQ REQ5664
       
  4040 //! @SYMTestCaseDesc Test asynchronous RFile API's
       
  4041 //! @SYMTestActions Test normal asynchronous read, share modes, read cancellation, race conditions
       
  4042 //! (with RFile::SetSize() and RFile::Write()), multiple asynchronous readers.
       
  4043 //! @SYMTestExpectedResults Expected behaviour reached.
       
  4044 //! @SYMTestPriority High
       
  4045 //! @SYMTestStatus Implemented
       
  4046 //---------------------------------------------
       
  4047 static void TestAsyncReader()
       
  4048 //
       
  4049 // Test asynchronous read notifications
       
  4050 //
       
  4051 	{
       
  4052 	TRequestStatus readStat1(KRequestPending);
       
  4053 	TRequestStatus readStat2(KRequestPending);
       
  4054 	TRequestStatus thrdStat(KRequestPending);
       
  4055 
       
  4056 	MakeFile(_L("\\F32-TST\\NOTIFY\\NewFile.Txt"));
       
  4057 
       
  4058 	test.Next(_L("Test original behaviour of asynchronous read API"));
       
  4059 	RFile reader;
       
  4060 	TInt r=reader.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileShareAny);
       
  4061 	test(r==KErrNone);
       
  4062 	TBuf8<596> readBuf;
       
  4063 	reader.Read(0, readBuf, 100, readStat1);
       
  4064 	User::WaitForRequest(readStat1);
       
  4065 	test(readStat1==KErrNone);
       
  4066 	test(readBuf.Length()==0);
       
  4067 	reader.Close();
       
  4068 
       
  4069 	test.Next(_L("Test asynchronous read fails in EFileShareExclusive mode"));
       
  4070 	r=reader.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileShareExclusive);
       
  4071 	test(r==KErrArgument);
       
  4072 
       
  4073 	test.Next(_L("Test asynchronous read fails in EFileShareReadersOnly mode"));
       
  4074 	r=reader.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileShareReadersOnly);
       
  4075 	test(r==KErrArgument);
       
  4076 
       
  4077 	test.Next(_L("Test asynchronous read is cancelled when file is closed"));
       
  4078 	r=reader.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileShareAny);
       
  4079 	test(r==KErrNone);
       
  4080 	reader.Read(0, readBuf, 100, readStat1);
       
  4081 	test(readStat1==KRequestPending);
       
  4082 	reader.Close();
       
  4083 	User::WaitForRequest(readStat1);
       
  4084 	test(readStat1==KErrCancel);
       
  4085 
       
  4086 	test.Next(_L("Test asynchronous read can be cancelled"));
       
  4087 	r=reader.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileShareAny);
       
  4088 	test(r==KErrNone);
       
  4089 	reader.Read(0, readBuf, 100, readStat1);
       
  4090 	test(readStat1==KRequestPending);
       
  4091 	reader.ReadCancel(readStat1);
       
  4092 	User::WaitForRequest(readStat1);
       
  4093 	test(readStat1==KErrCancel);
       
  4094 	reader.Close();
       
  4095 
       
  4096 	// DEF105438: File server thread safety issues
       
  4097 	// Up the priority of this thread so that we can cancel the request before the drive thread
       
  4098 	// runs (to test whether cancelling still works...)
       
  4099 	test.Next(_L("Test asynchronous read is cancelled when running at high priority"));
       
  4100 	r=reader.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileShareAny);
       
  4101 	test(r==KErrNone);
       
  4102 	RThread	thisThread;
       
  4103 	thisThread.SetPriority(EPriorityRealTime);
       
  4104 	reader.Read(0, readBuf, 100, readStat1);
       
  4105 	test(readStat1==KRequestPending);
       
  4106 	reader.ReadCancel(readStat1);
       
  4107 	test.Printf(_L("readStat1 %d"), readStat1.Int());
       
  4108 	User::WaitForRequest(readStat1);
       
  4109 	test(readStat1==KErrCancel);
       
  4110 	reader.Close();
       
  4111 	thisThread.SetPriority(EPriorityNormal);
       
  4112 
       
  4113 	test.Next(_L("Test asynchronous read is notified due to RFile::SetSize()"));
       
  4114 	r=reader.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileWrite|EFileShareAny);
       
  4115 	test(r==KErrNone);
       
  4116 	reader.Read(0, readBuf, 100, readStat1);
       
  4117 	test(readStat1==KRequestPending);
       
  4118 	r = reader.SetSize(100);
       
  4119 	test(r==KErrNone);
       
  4120 	User::WaitForRequest(readStat1);
       
  4121 	test(readStat1==KErrNone);
       
  4122 	test(readBuf.Length() == 100);
       
  4123 	r=reader.SetSize(0);
       
  4124 	test(r==KErrNone);
       
  4125 	reader.Close();
       
  4126 
       
  4127 	test.Next(_L("Test asynchronous read is notified due to RFile::Write()"));
       
  4128 	r=reader.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileWrite|EFileShareAny);
       
  4129 	test(r==KErrNone);
       
  4130 	reader.Read(0, readBuf, 26, readStat1);
       
  4131 	test(readStat1==KRequestPending);
       
  4132 	RFile writer;
       
  4133 	r=writer.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileWrite|EFileShareAny);
       
  4134 	writer.Write(_L8("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
       
  4135 	User::WaitForRequest(readStat1);
       
  4136 	test(readStat1==KErrNone);
       
  4137 	test(readBuf.Length() == 26);
       
  4138 	reader.Close();
       
  4139 	writer.Close();
       
  4140 
       
  4141 	test.Next(_L("Test multiple asynchronous readers notified from separate thread"));
       
  4142 	r=reader.Open(TheFs,_L("\\F32-TST\\NOTIFY\\NewFile.txt"),EFileRead|EFileReadAsyncAll|EFileWrite|EFileShareAny);
       
  4143 	test(r==KErrNone);
       
  4144 	r=reader.SetSize(0);
       
  4145 	test(r==KErrNone);
       
  4146 	const TInt KReadLen = 26;
       
  4147 	test.Printf(_L(">Read%d[%d]\n"), 0, KReadLen);
       
  4148 	reader.Read(0, readBuf, KReadLen, readStat1);
       
  4149 	TBuf8<596> readBuf2;
       
  4150 	test.Printf(_L(">Read%d[%d]\n"), 1, KReadLen);
       
  4151 	reader.Read(KReadLen, readBuf2, KReadLen, readStat2);
       
  4152 	test(readStat1==KRequestPending);
       
  4153 	test(readStat2==KRequestPending);
       
  4154 
       
  4155 	RThread thread;
       
  4156 	r=thread.Create(_L("MyThread"),ThreadEntryPoint,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)ETest12);
       
  4157 	test(r==KErrNone);
       
  4158 	thread.Logon(thrdStat);
       
  4159 	thread.Resume();
       
  4160 	thread.Close();
       
  4161 
       
  4162 	RTimer timer;
       
  4163 	TRequestStatus timerStat(KRequestPending);
       
  4164 	timer.CreateLocal();
       
  4165 	timer.After(timerStat, 30000000);	// 30 seconds timeout (the following async test should take 10 seconds)
       
  4166 	test(timerStat==KRequestPending);
       
  4167 
       
  4168 	#define ODDPASS  (pass&0x01)
       
  4169 	#define REQSTAT  (ODDPASS ? readStat2 : readStat1)
       
  4170 	#define PENDSTAT (ODDPASS ? readStat1 : readStat2)
       
  4171 	#define COMPLEN  (ODDPASS ? KReadLen  : (pass+1)*KReadLen)
       
  4172 	#define READLEN  (ODDPASS ? KReadLen  : (pass+3)*KReadLen)
       
  4173 	#define READPOS  (ODDPASS ? (pass+2)*KReadLen : 0)
       
  4174 	#define READBUF  (ODDPASS ? readBuf2 : readBuf)
       
  4175 
       
  4176 	TInt pass = 0;
       
  4177 	FOREVER
       
  4178 		{
       
  4179         User::WaitForRequest(REQSTAT, timerStat);
       
  4180 		test(REQSTAT==KErrNone);
       
  4181 		test(timerStat==KRequestPending);
       
  4182 		test(READBUF.Length() == COMPLEN);
       
  4183 		test(READBUF.Right(KReadLen) == _L8("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
       
  4184 		test.Printf(_L(">Read%d[%d]\n"), pass&0x01, READLEN);
       
  4185 		reader.Read(READPOS, READBUF, READLEN, REQSTAT);
       
  4186 		test(REQSTAT==KRequestPending);
       
  4187 		if(++pass==10)
       
  4188 			break;
       
  4189 		}
       
  4190 
       
  4191 	test.Next(_L("Close reader and test multiple outstanding requests are cancelled"));
       
  4192 	timer.Close();
       
  4193 	User::WaitForRequest(timerStat);
       
  4194 	reader.Close();
       
  4195 	User::WaitForRequest(readStat1);
       
  4196 	test(readStat1==KErrCancel);
       
  4197 	User::WaitForRequest(readStat2);
       
  4198 	test(readStat2==KErrCancel);
       
  4199 
       
  4200 	User::WaitForRequest(thrdStat);
       
  4201 	test(thrdStat==KErrNone);
       
  4202 	}
       
  4203 
       
  4204 
       
  4205 //-----------------------------------------------------------------------
       
  4206 
       
  4207 /**
       
  4208     Testing that TheFs.NotifyChange() works for the root directory of the drive
       
  4209 */
       
  4210 void TestRootDirNotifyChange()
       
  4211 {
       
  4212     test.Next(_L("Testing RFs::NotifyChange() on drive's root directory."));
       
  4213 
       
  4214     TInt nRes;
       
  4215     TRequestStatus reqStatNotify1(KRequestPending);
       
  4216 
       
  4217     _LIT(KTestPath, "\\"); //-- root dir, actually
       
  4218 
       
  4219     //-- set up notifier
       
  4220     TheFs.NotifyChange(ENotifyAll, reqStatNotify1, KTestPath);
       
  4221     test(reqStatNotify1.Int() == KRequestPending);
       
  4222 
       
  4223     //-- create a file in the root dir
       
  4224     RFile       file;
       
  4225     TFileName   fileName(KTestPath);
       
  4226 
       
  4227     fileName.Append(_L("TestFile.tst"));
       
  4228 
       
  4229     nRes=file.Replace(TheFs, fileName, EFileWrite|EFileRead);
       
  4230     test(nRes == KErrNone || nRes ==KErrAlreadyExists);
       
  4231     file.Close();
       
  4232 
       
  4233     //-- check that the notifier worked
       
  4234     User::WaitForRequest(reqStatNotify1);
       
  4235     test(reqStatNotify1.Int() == KErrNone);
       
  4236 
       
  4237 }
       
  4238 
       
  4239 
       
  4240 
       
  4241 //-----------------------------------------------------------------------
       
  4242 
       
  4243 //
       
  4244 // Do all tests
       
  4245 //
       
  4246 GLDEF_C void CallTestsL()
       
  4247 	{
       
  4248 
       
  4249 	CreateTestDirectory(_L("\\F32-TST\\NOTIFY\\"));
       
  4250 
       
  4251 //	Test RFs::NotifyChange()
       
  4252 	CHECK_NO_PENDING_REQUESTS;
       
  4253 	Test1();
       
  4254 	CHECK_NO_PENDING_REQUESTS;
       
  4255 	Test2();
       
  4256 	CHECK_NO_PENDING_REQUESTS;
       
  4257 	Test3();
       
  4258 	CHECK_NO_PENDING_REQUESTS;
       
  4259 	Test4();
       
  4260 	CHECK_NO_PENDING_REQUESTS;
       
  4261 	Test5();
       
  4262 	CHECK_NO_PENDING_REQUESTS;
       
  4263 
       
  4264 #if defined (__EPOC32__)//we have no removable media on Emulator yet	.. ??? we do now
       
  4265 #if defined __INCLUDE_MANUAL_TESTS__
       
  4266 
       
  4267 	// Media change notification on every socket supported
       
  4268 	TInt i;
       
  4269 	for (i=0; i<KMaxPBusSockets; i++)
       
  4270 		SocketToDrive[i]=-1;
       
  4271 	TDriveInfoV1Buf dinfo;
       
  4272 	UserHal::DriveInfo(dinfo);
       
  4273 	TDriveInfoV1 &di=dinfo();
       
  4274 	TInt driveCount=dinfo().iTotalSupportedDrives;
       
  4275 	TInt socketCount=dinfo().iTotalSockets;
       
  4276 	TInt drv;
       
  4277 	test.Printf(_L("Socket count: %d\n"), socketCount);
       
  4278 	TUint32 mask=~(0xffffffffu<<socketCount);
       
  4279 
       
  4280 	for (drv=0; drv<driveCount; drv++)
       
  4281 		{
       
  4282 		TBool flag=EFalse;
       
  4283 		RLocalDrive d;
       
  4284 		TInt r=d.Connect(drv,flag);
       
  4285 
       
  4286 		//Not all the drives are used at present
       
  4287 		if (r == KErrNotSupported)
       
  4288 			continue;
       
  4289 
       
  4290 		test(r==KErrNone);
       
  4291 		TInt sockNum = 0;
       
  4292 		if (d.IsRemovable(sockNum)>0)
       
  4293 			{
       
  4294 			if (mask & (1<<sockNum))
       
  4295 				{
       
  4296 				SocketToDrive[sockNum]=drv;
       
  4297 				mask &= ~(1<<sockNum);
       
  4298 				}
       
  4299 			}
       
  4300 		d.Close();
       
  4301 		}
       
  4302 
       
  4303 
       
  4304 	// Manual media change test
       
  4305 	for (gSocketNumber=socketCount-1; gSocketNumber>=0; gSocketNumber--)
       
  4306 		{
       
  4307 		if (SocketToDrive[gSocketNumber] != -1)
       
  4308 			{
       
  4309 			test.Printf(_L("Testing socket %u, drive %u...\n"),
       
  4310 				gSocketNumber, SocketToDrive[gSocketNumber]);
       
  4311 			Test99();
       
  4312 			}
       
  4313 		}
       
  4314 #endif
       
  4315     Test6();
       
  4316 #endif
       
  4317 	CHECK_NO_PENDING_REQUESTS;
       
  4318 	Test7();
       
  4319 	CHECK_NO_PENDING_REQUESTS;
       
  4320 
       
  4321 
       
  4322 #if defined (__EPOC32__)//we have no removable media on Emulator yet
       
  4323 
       
  4324 //	Test RFs::NotifyChange() extended notification
       
  4325 	TInt uid;
       
  4326 	test(HAL::Get(HAL::EMachineUid,uid)==KErrNone);
       
  4327 	if(uid!=HAL::EMachineUid_Cogent && uid!=HAL::EMachineUid_IQ80310 &&
       
  4328 				uid != HAL::EMachineUid_Integrator && uid!=HAL::EMachineUid_X86PC)
       
  4329 		MediaChangeExtendedNotification();
       
  4330 
       
  4331 #endif
       
  4332 
       
  4333 	CHECK_NO_PENDING_REQUESTS;
       
  4334 	TestRequestAhead();
       
  4335 	CHECK_NO_PENDING_REQUESTS;
       
  4336 	Test8();
       
  4337 	CHECK_NO_PENDING_REQUESTS;
       
  4338 	Test9();
       
  4339 	CHECK_NO_PENDING_REQUESTS;
       
  4340 	Test10();
       
  4341 	CHECK_NO_PENDING_REQUESTS;
       
  4342 	Test11();
       
  4343 	CHECK_NO_PENDING_REQUESTS;
       
  4344 	Test12();
       
  4345 	CHECK_NO_PENDING_REQUESTS;
       
  4346 	Test13();
       
  4347 	CHECK_NO_PENDING_REQUESTS;
       
  4348 	Test14();
       
  4349 	CHECK_NO_PENDING_REQUESTS;
       
  4350 	Test15();
       
  4351 	CHECK_NO_PENDING_REQUESTS;
       
  4352 	Test16();
       
  4353 	CHECK_NO_PENDING_REQUESTS;
       
  4354 	Test17();
       
  4355 	CHECK_NO_PENDING_REQUESTS;
       
  4356 	Test18();
       
  4357 	CHECK_NO_PENDING_REQUESTS;
       
  4358 	TestAsyncReader();
       
  4359 	CHECK_NO_PENDING_REQUESTS;
       
  4360 	DeleteTestDirectory();
       
  4361 	CHECK_NO_PENDING_REQUESTS;
       
  4362     TestRootDirNotifyChange();
       
  4363 	CHECK_NO_PENDING_REQUESTS;
       
  4364 	}