kerneltest/f32test/server/t_dlocl.cpp
changeset 0 a41df078684a
child 43 c1f20ce4abcf
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kerneltest/f32test/server/t_dlocl.cpp	Mon Oct 19 15:55:17 2009 +0100
@@ -0,0 +1,773 @@
+// Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of the License "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// f32test\server\t_dlocl.cpp
+// Tests UserSvr::ChangeLocale() function
+// 
+//
+
+#define __E32TEST_EXTENSION__
+
+#include <e32std.h>
+#include <e32std_private.h>
+#include <e32test.h>
+#include <f32file.h>
+#include <e32svr.h>
+#include <collate.h>
+
+#include "t_server.h"
+
+LOCAL_D TFindLibrary fLib;
+
+typedef TInt (*TLibEntry)(TInt);
+typedef TInt (*TLibEntry2)();
+
+const TBool KEY_DOWN=EFalse;
+const TBool EXPECT_KEY_PRESS=ETrue;
+
+RTest test(_L("T_DLOCL"));
+
+_LIT(ELOCL_DEFAULT, "");
+_LIT(ELOCLGE, "T_LOCLGE");
+_LIT(ELOCLUS, "T_LOCLUS");
+_LIT(ELOCLUS1, "T_LOCLUS1");
+_LIT(ELOCLUS2, "T_LOCLUS2");
+_LIT(EKDATA, "EKDATA");
+_LIT(DUMMYDLL, "EDISP");
+_LIT(KColonColon, "::");
+_LIT(KDLLExtension, ".DLL");
+
+GLDEF_D CKeyTranslator *KeyTranslator=CKeyTranslator::New();
+LOCAL_D CCaptureKeys *CaptureKeys;
+
+void testConv(const TDesC& aDes,TBool aKeyup,TBool aRet,TUint aScanCode,TUint aKeyCode,TInt aModifiers)
+    {
+
+    TKeyData keyData;
+    TBool ret=KeyTranslator->TranslateKey(aScanCode, aKeyup,*CaptureKeys,keyData);
+    test.Next(aDes);
+    test(ret==aRet);
+    test((keyData.iKeyCode==aKeyCode));
+    test((keyData.iModifiers==aModifiers));
+    }
+
+void testChangeKeyData()
+    {
+    TName pn(RProcess().Name());
+    pn+=KColonColon;
+    TFullName n;
+    CaptureKeys=new CCaptureKeys();
+    CaptureKeys->Construct();
+    test.Printf(_L("Test default key data\n"));
+    testConv(_L("\nFirst Special key down"),KEY_DOWN,EXPECT_KEY_PRESS,ESpecialKeyBase,ESpecialKeyBase,0);
+
+    RLibrary testLib;
+    TInt res=testLib.Load(EKDATA);
+    test(res==KErrNone);
+    THandleInfo handleInfo;
+    testLib.HandleInfo(&handleInfo);
+    test(handleInfo.iNumOpenInThread==2);
+    testLib.Close();
+
+    test.Printf(_L("Change to unknown dll \n"));                // Test with non keydata type dll
+    res=KeyTranslator->ChangeKeyData(DUMMYDLL);
+    test(res==KErrArgument);
+    
+    res=testLib.Load(EKDATA);
+    test(res==KErrNone);
+    testLib.HandleInfo(&handleInfo);
+    test(handleInfo.iNumOpenInThread==2);
+    testLib.Close();
+
+    res=testLib.Load(DUMMYDLL);
+    test(res==KErrNone);
+    testLib.HandleInfo(&handleInfo);
+    test(handleInfo.iNumOpenInThread==1);
+    testLib.Close();
+
+    fLib.Find(_L("*"));
+    while (fLib.Next(n)==KErrNone)
+        {
+        TName findname=pn;
+        findname+=DUMMYDLL;
+        test.Printf(_L("  %S\n"),&n);        
+        test(n.FindF(findname) == KErrNotFound);
+        }
+    //
+    test.Printf(_L("Change to EKDATA.dll\n"));
+    res=KeyTranslator->ChangeKeyData(EKDATA);
+    test(res==KErrNone);
+    
+    res=testLib.Load(EKDATA);
+    test(res==KErrNone);
+    testLib.HandleInfo(&handleInfo);
+    test(handleInfo.iNumOpenInThread==2);
+    testLib.Close();
+    res=testLib.Load(DUMMYDLL);
+    test(res==KErrNone);
+    testLib.HandleInfo(&handleInfo);
+    test(handleInfo.iNumOpenInThread==1);
+    testLib.Close();
+
+    fLib.Find(_L("*"));
+    while (fLib.Next(n)==KErrNone)
+        {
+        TName findname=pn;
+        findname+=EKDATA;
+        test.Printf(_L("  %S\n"),&n);        
+        if(n.FindF(findname) != KErrNotFound)
+            break;
+        }
+    //The test below fails if we use Secure APIs
+    //test(n.FindF(EKDATA) == KErrNotSupported);
+    testConv(_L("\nFirst Special key down"),KEY_DOWN,EXPECT_KEY_PRESS,ESpecialKeyBase,ESpecialKeyBase,0);
+
+    test.Printf(_L("Change back to Default KeyData\n"));
+    res=KeyTranslator->ChangeKeyData(_L(""));
+    test(res==KErrNone);
+    
+    res=testLib.Load(EKDATA);
+    test(res==KErrNone);
+    testLib.HandleInfo(&handleInfo);
+    test(handleInfo.iNumOpenInThread==2);
+    testLib.Close();
+
+    res=testLib.Load(DUMMYDLL);
+    test(res==KErrNone);
+    testLib.HandleInfo(&handleInfo);
+    test(handleInfo.iNumOpenInThread==1);
+    testLib.Close();
+
+    fLib.Find(_L("*"));
+    while (fLib.Next(n)==KErrNone)
+        {
+        TName findname=pn;
+        findname+=DUMMYDLL;
+        test.Printf(_L("  %S\n"),&n);        
+        test(n.FindF(findname) == KErrNotFound);
+        }
+    testConv(_L("\nFirst Special key down"),KEY_DOWN,EXPECT_KEY_PRESS,ESpecialKeyBase,ESpecialKeyBase,0);
+    delete CaptureKeys;
+    }
+
+void testUS(const TLocale& aLocale)
+    {
+//#ifdef __WINS__
+    test(aLocale.CountryCode()==1);
+    test(aLocale.DateFormat()==EDateAmerican);
+    test(aLocale.TimeFormat()==ETime12);
+    test(aLocale.CurrencySymbolPosition()==ELocaleBefore);
+    test(aLocale.CurrencySpaceBetween()==FALSE);
+    test(aLocale.CurrencyDecimalPlaces()==2);
+    test(aLocale.CurrencyNegativeInBrackets()==EFalse);
+    test(aLocale.CurrencyTriadsAllowed()==TRUE);
+    test(aLocale.ThousandsSeparator()==',');
+    test(aLocale.DecimalSeparator()=='.');
+    test(aLocale.DateSeparator(0)==0);
+    test(aLocale.DateSeparator(1)=='/');
+    test(aLocale.DateSeparator(2)=='/');
+    test(aLocale.DateSeparator(3)==0);
+    test(aLocale.TimeSeparator(0)==0);
+    test(aLocale.TimeSeparator(1)==':');
+    test(aLocale.TimeSeparator(2)==':');
+    test(aLocale.TimeSeparator(3)==0);
+    test(aLocale.AmPmSymbolPosition()==TRUE);
+    test(aLocale.AmPmSpaceBetween()==TRUE);
+    test(aLocale.HomeDaylightSavingZone()==EDstNorthern);
+    test(aLocale.WorkDays()==0x1f);
+    test(aLocale.StartOfWeek()==ESunday);
+    test(aLocale.ClockFormat()==EClockAnalog);
+    test(aLocale.UnitsGeneral()==EUnitsImperial);
+    test(aLocale.UnitsDistanceShort()==EUnitsImperial);
+    test(aLocale.UnitsDistanceLong()==EUnitsImperial);
+//#endif
+    }
+
+
+void testUK(const TLocale& aLocale)
+    {
+//#ifdef __WINS__
+    test(aLocale.CountryCode()==44);
+    test(aLocale.DateFormat()==EDateEuropean);
+    test(aLocale.TimeFormat()==ETime12);
+    test(aLocale.CurrencySymbolPosition()==ELocaleBefore);
+    test(aLocale.CurrencySpaceBetween()==FALSE);
+    test(aLocale.CurrencyDecimalPlaces()==2);
+    test(aLocale.CurrencyNegativeInBrackets()==EFalse);
+    test(aLocale.CurrencyTriadsAllowed()==TRUE);
+    test(aLocale.ThousandsSeparator()==',');
+    test(aLocale.DecimalSeparator()=='.');
+    test(aLocale.DateSeparator(0)==0);
+    test(aLocale.DateSeparator(1)=='/');
+    test(aLocale.DateSeparator(2)=='/');
+    test(aLocale.DateSeparator(3)==0);
+    test(aLocale.TimeSeparator(0)==0);
+    test(aLocale.TimeSeparator(1)==':');
+    test(aLocale.TimeSeparator(2)==':');
+    test(aLocale.TimeSeparator(3)==0);
+    test(aLocale.AmPmSymbolPosition()==TRUE);
+    test(aLocale.AmPmSpaceBetween()==TRUE);
+    test(aLocale.HomeDaylightSavingZone()==EDstEuropean);
+    test(aLocale.WorkDays()==0x1f);
+    test(aLocale.StartOfWeek()==EMonday);
+    test(aLocale.ClockFormat()==EClockAnalog);
+    test(aLocale.UnitsGeneral()==EUnitsImperial);
+    test(aLocale.UnitsDistanceShort()==EUnitsImperial);
+    test(aLocale.UnitsDistanceLong()==EUnitsImperial);
+//#endif
+    }
+
+void testGE(const TLocale& aLocale)
+    {
+//#ifdef __WINS__
+    test(aLocale.CountryCode()==49);
+    test(aLocale.DateFormat()==EDateEuropean);
+    test(aLocale.TimeFormat()==ETime24);
+    test(aLocale.CurrencySymbolPosition()==ELocaleAfter);
+    test(aLocale.CurrencySpaceBetween()==TRUE);
+    test(aLocale.CurrencyDecimalPlaces()==2);
+    test(aLocale.CurrencyNegativeInBrackets()==TRUE);
+    test(aLocale.CurrencyTriadsAllowed()==TRUE);
+    test(aLocale.ThousandsSeparator()=='.');
+    test(aLocale.DecimalSeparator()==',');
+    test(aLocale.DateSeparator(0)==0);
+    test(aLocale.DateSeparator(1)=='.');
+    test(aLocale.DateSeparator(2)=='.');
+    test(aLocale.DateSeparator(3)==0);
+
+    test(aLocale.TimeSeparator(0)==0);
+    test(aLocale.TimeSeparator(1)==':');
+    test(aLocale.TimeSeparator(2)==':');
+    test(aLocale.TimeSeparator(3)==0);
+    test(aLocale.AmPmSymbolPosition()==TRUE);
+    test(aLocale.AmPmSpaceBetween()==TRUE);
+    test(aLocale.HomeDaylightSavingZone()==EDstEuropean);
+    test(aLocale.WorkDays()==0x1f);
+    test(aLocale.StartOfWeek()==EMonday);
+    test(aLocale.ClockFormat()==EClockDigital);
+    test(aLocale.UnitsGeneral()==EUnitsMetric);
+    test(aLocale.UnitsDistanceShort()==EUnitsMetric);
+    test(aLocale.UnitsDistanceLong()==EUnitsMetric);
+//#endif
+    }
+
+
+
+/**
+    Subscribe to a system event.
+
+    @param  aNotifier   notifier
+    @param  aStatus     request status that is used with the notifier
+    @param  aEventMask  Specifies the event. See TChanges
+*/
+static void SubscribeToSystemChangeNotification(RChangeNotifier& aNotifier, TRequestStatus& aStatus, TUint32 aEventMask)
+{
+    
+    const TInt KMaxAttempts = 100;
+    TInt i;
+    for(i=0; i<KMaxAttempts; ++i)
+    {
+        test.Printf(_L("SubscribeToSystemChangeNotification(0x%x), attempt:%d\n"), aEventMask, i);   
+
+        TInt nRes = aNotifier.Logon(aStatus);
+        test(nRes==KErrNone);
+
+        if(aStatus.Int() == KRequestPending)
+            break;
+
+        //-- some other system-wide event can just happen; re-subscribe
+        test( !(aStatus.Int() & aEventMask));
+    }
+
+    test(i<KMaxAttempts);
+}
+
+/**
+    Wait for the event(s) specified in aEventMask to happen
+
+    @param  aNotifier   notifier
+    @param  aStatus     request status that is used with the notifier
+    @param  aEventMask  Specifies the event. See TChanges
+*/
+static void WaitForSystemChange(RChangeNotifier& aNotifier, TRequestStatus& aStatus, TUint32 aEventMask)
+{
+    //-- it would be nice to have here a timeout processing in order not to wait forever.. but later.
+    for(;;)
+    {
+        User::WaitForRequest(aStatus);
+        if(aStatus.Int() & aEventMask)
+            return; 
+
+        //-- some other system-wide unexpected event happened, we need to resubscribe
+        test.Printf(_L("WaitForSystemChange(0x%x), happened:0x%x, resubscribing...\n"), aEventMask, aStatus.Int());   
+        SubscribeToSystemChangeNotification(aNotifier, aStatus, aEventMask);
+    }
+
+}
+    
+
+void testChangeLocale()
+    {
+    TLocale locale;
+    
+    RChangeNotifier notifier;
+    TInt res=notifier.Create();
+    test(res==KErrNone);
+    TRequestStatus stat;
+    
+    res=notifier.Logon(stat);
+    test(res==KErrNone);
+	// initial value of stat already tested by t_chnot
+
+    SubscribeToSystemChangeNotification(notifier, stat, EChangesLocale);
+
+        test.Printf(_L("Change to US Locale\n"));   
+        res=UserSvr::ChangeLocale(ELOCLUS);
+        test.Printf(_L("res=%d\n"),res);
+        test(res==KErrNone);
+
+    WaitForSystemChange(notifier, stat, EChangesLocale);
+    test(stat.Int() & EChangesLocale);
+    
+    //-------------------
+    SubscribeToSystemChangeNotification(notifier, stat, EChangesLocale);
+        
+        locale.Refresh();
+        // let's not test localisation data details now that the internationalisation
+        // team rather than us release the localisation dlls (changed 9/6/98)
+        testUS(locale);
+
+        test.Printf(_L("Change to GE Locale\n"));
+        res=UserSvr::ChangeLocale(ELOCLGE);
+        test.Printf(_L("res=%d\n"),res);
+        test(res==KErrNone);
+
+    WaitForSystemChange(notifier, stat, EChangesLocale);
+    test(stat.Int() & EChangesLocale);
+    
+    //-------------------
+    
+    SubscribeToSystemChangeNotification(notifier, stat, EChangesLocale);
+        
+        locale.Refresh();
+        // let's not test localisation data details now that the internationalisation
+        // team rather than us release the localisation dlls (changed 9/6/98)
+        testGE(locale);
+
+        test.Printf(_L("Load non ELOCL type DLL\n"));    
+        res=UserSvr::ChangeLocale(DUMMYDLL);
+        test.Printf(_L("res=%d\n"),res);
+        test(res == KErrNotSupported);
+    
+    //-- ensure that there wasn't locale change
+    const TInt KMaxAttempts = 100;
+	TInt i;
+    for(i=0; i<KMaxAttempts; ++i)
+    {
+        if(stat ==KRequestPending)
+            break;
+        
+        //-- check that if something system-wide happened, it wasn't a locale change
+        test(!(stat.Int() & EChangesLocale));
+        SubscribeToSystemChangeNotification(notifier, stat, EChangesLocale);
+    }
+    test(i<KMaxAttempts);
+
+
+        locale.Refresh();
+        // let's not test localisation data details now that the internationalisation
+        // team rather than us release the localisation dlls (changed 9/6/98)
+        testGE(locale);
+
+        //This test using US1 locale is for identifying different collation table
+        //used for matching and comparing. To specify a table to be used in the
+        //matching we just need to add the TCollationTable::EMatchingTable flag
+        //inside the TCollationMethods::iFlags
+        test.Printf(_L("Change to US1 Locale\n"));  
+        res=UserSvr::ChangeLocale(ELOCLUS1);
+        test.Printf(_L("res=%d\n"),res);
+        test(res==KErrNone);
+    
+    WaitForSystemChange(notifier, stat, EChangesLocale);
+    test(stat.Int() & EChangesLocale);
+
+    
+    //-------------------
+    SubscribeToSystemChangeNotification(notifier, stat, EChangesLocale);
+
+        locale.Refresh();
+    
+    //Testing the different collation table used for Matching and Comparing
+    //after loading this new locale using T_LOCLUS1.DLL.
+    //test.Printf(_L("Test for differnt collation table for Matching and Comparing\n"));
+    //TCollationMethod m=*Mem::GetDefaultMatchingTable();
+    //test(m.iFlags & TCollationMethod::EMatchingTable);
+    
+    //The collation table t_locl.cpp can be found in \locl\t_locl.cpp
+    //Expected collation override for MatchC A==B and a==b
+    //Expected collation override for CompareC A>B and a>b
+    //Collation tables cannot be changed at runtime
+/*  TBuf16<1> a_cap(_L("A"));
+    TBuf16<1> a_small(_L("a"));
+    
+    //Test using the locale independent matching and comparing
+    test(a_cap.Match(_L("B"))!=0);
+    test(a_cap.Compare(_L("B"))<0);
+    test(a_small.Match(_L("b"))!=0);
+    test(a_small.Compare(_L("b"))<0);
+    //Test that the default collation table(1st table) is selected here
+    test(a_cap.CompareC(_L("B"))!=0);
+    test(a_small.CompareC(_L("b"))!=0);
+    test(a_cap.CompareC(_L("B"))>0);
+    test(a_small.CompareC(_L("b"))>0);
+    //Test that the Matching collation table(3rd table) is selected here
+    test(a_cap.MatchC(_L("B"))==0);
+    test(a_small.MatchC(_L("b"))==0);
+*/
+        test.Printf(_L("Back to default UK Locale\n"));
+        res=UserSvr::ChangeLocale(ELOCL_DEFAULT);
+        test.Printf(_L("res=%d\n"),res);
+        test(res==KErrNone);
+    
+    WaitForSystemChange(notifier, stat, EChangesLocale);
+    test(stat.Int() & EChangesLocale);
+    
+    //-------------------
+
+    SubscribeToSystemChangeNotification(notifier, stat, EChangesLocale);
+
+        locale.Refresh();
+        testUK(locale); 
+    
+        //Test for locale which does not have a matching collation table
+        TCollationMethod m1=*Mem::GetDefaultMatchingTable();
+        test((m1.iFlags & TCollationMethod::EMatchingTable)==0);
+
+        //************************************************
+        test.Printf(_L("Change to US Locale with file open on drive\n"));   
+    
+        _LIT(KTestFile, "TEST.TXT");
+        RFile file;
+        res = file.Replace(TheFs, KTestFile, 0);
+        test(res == KErrNone);
+
+
+        res=UserSvr::ChangeLocale(ELOCLUS);
+        test.Printf(_L("res=%d\n"),res);
+        test(res==KErrNone);
+
+
+    WaitForSystemChange(notifier, stat, EChangesLocale);
+    test(stat.Int() & EChangesLocale);
+
+    
+    //-------------------
+    SubscribeToSystemChangeNotification(notifier, stat, EChangesLocale);
+
+
+        _LIT8(KTestData, "Arsenal");
+        res = file.Write(KTestData);
+        test(res==KErrNone);
+        file.Close();
+
+        res = file.Open(TheFs, KTestFile, 0);
+        test(res == KErrNone);
+        file.Close();
+        res = TheFs.Delete(KTestFile);
+        test(res==KErrNone);
+
+    //************************************************
+
+    //-- close the notifier
+    notifier.Close();
+    User::WaitForRequest(stat);
+    
+    //-- n.b. it's actually a bad idea to expect _exact_ event completion from the RChangeNotifier, because
+    //-- this is a system-wide events observer and any of the TChanges events can happen, not only EChangesLocale.
+    //-- so this test is a bit flawed.
+
+    //test(stat==KErrGeneral);
+    }
+
+const TText * const DateSuffixTable[KMaxSuffixes] =
+    {
+    _S("st"),_S("nd"),_S("rd"),_S("th"),_S("th"),
+    _S("th"),_S("th"),_S("th"),_S("th"),_S("th"),
+    _S("th"),_S("th"),_S("th"),_S("th"),_S("th"),
+    _S("th"),_S("th"),_S("th"),_S("th"),_S("th"),
+    _S("st"),_S("nd"),_S("rd"),_S("th"),_S("th"),
+    _S("th"),_S("th"),_S("th"),_S("th"),_S("th"),
+    _S("st")
+    };
+
+const TText * const DayTable[KMaxDays] =
+    {
+    _S("Monday"),
+    _S("Tuesday"),
+    _S("Wednesday"),
+    _S("Thursday"),
+    _S("Friday"),
+    _S("Saturday"),
+    _S("Sunday")
+    };
+
+const TText * const DayAbbTable[KMaxDays] =
+    {
+    _S("Mon"),
+    _S("Tue"),
+    _S("Wed"),
+    _S("Thu"),
+    _S("Fri"),
+    _S("Sat"),
+    _S("Sun")
+    };
+
+const TText * const MonthTable[KMaxMonths] =
+    {
+    _S("January"),
+    _S("February"),
+    _S("March"),
+    _S("April"),
+    _S("May"),
+    _S("June"),
+    _S("July"),
+    _S("August"),
+    _S("September"),
+    _S("October"),
+    _S("November"),
+    _S("December")
+    };
+
+const TText * const MonthAbbTable[KMaxMonths] =
+    {
+    _S("Jan"),
+    _S("Feb"),
+    _S("Mar"),
+    _S("Apr"),
+    _S("May"),
+    _S("Jun"),
+    _S("Jul"),
+    _S("Aug"),
+    _S("Sep"),
+    _S("Oct"),
+    _S("Nov"),
+    _S("Dec")
+    };
+
+const TText * const AmPmTable[KMaxAmPms] = {_S("am"),_S("pm")};
+
+void testExtendedUS(TUint aAspect, TExtendedLocale& aLocale)
+    {
+    TLocale* loc = aLocale.GetLocale();
+    testUS(*loc);
+    
+    if(aAspect & ELocaleLanguageSettings)
+        {
+        TLanguage tl = User::Language();
+        test(tl == ELangAmerican);
+        
+        TDateSuffix datesuffix;
+        TInt i;
+        for(i=0;i<KMaxSuffixes;++i)
+            {
+            datesuffix.Set(i);
+            test(datesuffix.Compare(TPtrC(DateSuffixTable[i])) == 0);
+            }
+
+        TDayName dayname;
+        for(i=0;i<KMaxDays;++i)
+            {
+            dayname.Set((TDay)i);
+            test(dayname.Compare(TPtrC(DayTable[i])) == 0);
+            }
+
+        TDayNameAbb daynameabb;
+        for(i=0;i<KMaxDays;++i)
+            {
+            daynameabb.Set((TDay)i);
+            test(daynameabb.Compare(TPtrC(DayAbbTable[i])) == 0);
+            }
+
+        TMonthName monthname;
+        for(i=0;i<KMaxMonths;++i)
+            {
+            monthname.Set((TMonth)i);
+            test(monthname.Compare(TPtrC(MonthTable[i])) == 0);
+            }
+
+        TMonthNameAbb monthnameabb;
+        for(i=0;i<KMaxMonths;++i)
+            {
+            monthnameabb.Set((TMonth)i);
+            test(monthnameabb.Compare(TPtrC(MonthAbbTable[i])) == 0);
+            }
+
+        TAmPmName ampmname;
+        for(i=0;i<KMaxAmPms;++i)
+            {
+            ampmname.Set((TAmPm)i);
+            test(ampmname.Compare(TPtrC(AmPmTable[i])) == 0);
+            }
+        }
+
+    if(aAspect & ELocaleLocaleSettings)
+        {
+        TCurrencySymbol symbol;
+        symbol.Set();
+        test(symbol.Compare(TPtrC(_S("$"))) == 0);
+        }
+
+    if(aAspect & ELocaleTimeDateSettings)
+        {
+        TShortDateFormatSpec shortdate;
+        shortdate.Set();
+        test(shortdate.Compare(TPtrC(_S("%F%*M/%*D/%Y"))) == 0);
+
+        TLongDateFormatSpec longdate;
+        longdate.Set();
+        test(longdate.Compare(TPtrC(_S("%F%*D%X %N %Y"))) == 0);
+
+        TTimeFormatSpec spec;
+        spec.Set();
+        test(spec.Compare(TPtrC(_S("%F%*I:%T:%S %*A"))) == 0);
+        }
+
+    }
+
+    
+void testExtendedLocale()
+    {
+    TExtendedLocale locale;
+    locale.LoadLocale(ELOCLUS);
+    TInt r = locale.SaveSystemSettings();
+    test(r == KErrNone);
+    testExtendedUS(ELocaleLanguageSettings | ELocaleCollateSetting | ELocaleLocaleSettings | ELocaleTimeDateSettings, locale);
+
+    r = locale.SetCurrencySymbol(TPtrC(_S("Leu")));
+    test(r == KErrNone);
+    TCurrencySymbol symbol;
+    symbol.Set();
+    test(symbol.Compare(TPtrC(_S("Leu"))) == 0);
+
+    User::SetCurrencySymbol(TPtrC(_S("Le")));
+    symbol.Set();
+    test(symbol.Compare(TPtrC(_S("Le"))) == 0);
+
+    TFileName dllName;
+    TFileName eloclus;
+    eloclus.Copy(ELOCLUS);
+    eloclus.Append(TPtrC(KDLLExtension));
+    r = locale.GetLocaleDllName(ELocaleLanguageSettings, dllName);
+    test(r == KErrNone);
+    test.Printf(_L("dllName looking for %s (%s)\n"), dllName.Ptr(), eloclus.Ptr());
+    test(dllName.Find(eloclus) != KErrNotFound);
+    
+    dllName.FillZ();
+
+    r = locale.GetLocaleDllName(ELocaleCollateSetting, dllName);
+    test(r == KErrNone);
+    test(dllName.Find(eloclus) != KErrNotFound);
+    
+    dllName.FillZ();
+
+    r = locale.GetLocaleDllName(ELocaleLocaleSettings, dllName);
+    test(r == KErrNone);
+    test(dllName.Find(eloclus) != KErrNotFound);
+    
+    dllName.FillZ();
+
+    r = locale.GetLocaleDllName(ELocaleTimeDateSettings, dllName);
+    test(r == KErrNone);
+    test(dllName.Find(eloclus) != KErrNotFound);
+    
+    dllName.FillZ();
+
+    r = locale.LoadLocaleAspect(ELocaleLocaleSettings | ELocaleTimeDateSettings, ELOCLGE);
+    test(r == KErrNone);
+
+    r = locale.SaveSystemSettings();
+    test(r == KErrNone);
+
+    testExtendedUS(ELocaleLanguageSettings | ELocaleCollateSetting, locale);
+
+    symbol.Set();
+    test(symbol.Compare(TPtrC(_S("DM"))) == 0);
+
+    TShortDateFormatSpec shortdate;
+    shortdate.Set();
+    test(shortdate.Compare(TPtrC(_S("%F%*D.%*M.%Y"))) == 0);
+
+    TLongDateFormatSpec longdate;
+    longdate.Set();
+    test(longdate.Compare(TPtrC(_S("%F%*D%X %N %Y"))) == 0);
+
+    TTimeFormatSpec spec;
+    spec.Set();
+    test(spec.Compare(TPtrC(_S("%F%H:%T:%S"))) == 0);
+
+    TFileName eloclge;
+    eloclge.Copy(ELOCLGE);
+    eloclge.Append(KDLLExtension);
+    r = locale.GetLocaleDllName(ELocaleLanguageSettings, dllName);
+    test(r == KErrNone);
+    test(dllName.Find(eloclus) != KErrNotFound);
+    
+    dllName.FillZ();
+
+    r = locale.GetLocaleDllName(ELocaleCollateSetting, dllName);
+    test(r == KErrNone);
+    test(dllName.Find(eloclus) != KErrNotFound);
+    
+    dllName.FillZ();
+
+    r = locale.GetLocaleDllName(ELocaleLocaleSettings, dllName);
+    test(r == KErrNone);
+    test(dllName.Find(eloclge) != KErrNotFound);
+    
+    dllName.FillZ();
+
+    r = locale.GetLocaleDllName(ELocaleTimeDateSettings, dllName);
+    test(r == KErrNone);
+    test(dllName.Find(eloclge) != KErrNotFound);
+    
+    dllName.FillZ();
+
+    }
+
+void testDigitsInMonthsNames()
+    {
+    test.Next(_L("Testing date parsing when month names include digits"));
+
+    TTime time;
+    _LIT(KMonthJan, "30 Th1 2006 14:31:50");
+    test_Equal(KErrArgument, time.Parse(KMonthJan));
+    test_KErrNone(UserSvr::ChangeLocale(ELOCLUS2));
+    test_Equal(EParseDatePresent | EParseTimePresent, time.Parse(KMonthJan));
+    test_KErrNone(UserSvr::ChangeLocale(ELOCL_DEFAULT));
+    }
+
+GLDEF_C void CallTestsL(void)
+    {
+
+    test.Title();
+    test.Start(_L("Starting T_DLOCL tests"));
+
+    testChangeLocale();
+    testChangeKeyData();
+    testExtendedLocale();
+    testDigitsInMonthsNames();
+    test.Next(_L("Close connection to the file server\n"));
+
+    test.End();
+    }
+