--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/userlibandfileserver/fatfilenameconversionplugins/test/T_CP54936.CPP Mon Oct 19 15:55:17 2009 +0100
@@ -0,0 +1,848 @@
+// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of the License "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+//
+
+#include <e32test.h>
+#include <e32des8.h>
+#include <hal.h>
+
+LOCAL_D RTest test(_L("T_CP54936.exe"));
+
+
+_LIT(KName,"CP54936");
+const TUid KPluginUid={0x1028703b};
+
+
+void TestOut(const TDesC16 &des)
+ {
+ for (TInt i=0; i<des.Length(); i++)
+ test.Printf(_L("%04X "), des[i]);
+ }
+
+void TestOut(const TDesC8 &des)
+ {
+ for (TInt i=0; i<des.Length(); i++)
+ test.Printf(_L("%02X "), des[i]);
+ }
+
+// Used for supressing warning in OOM tests
+#define __UNUSED_VAR(var) var = var
+
+/**
+@SYMTestCaseID SYSLIB-FATCHARSETCONV-CT-1778
+@SYMTestCaseDesc Tests API behaviours of UnicodeConv class
+@SYMTestPriority High
+@SYMTestActions Tests for conversions from/to Unicode, using a function pointer
+@SYMTestExpectedResults Test must not fail
+*/
+void Test()
+ {
+ test.Next(_L(" @SYMTestCaseID:SYSLIB-FATCHARSETCONV-CT-1778 "));
+ RLibrary lib;
+
+ const TUidType serverUid(KNullUid,KNullUid,KPluginUid);
+ // load the dll
+ TInt returnValue = lib.Load(KName,serverUid);
+ test(returnValue==0);
+
+ // get a pointer to the specified ordinal function and call it
+ TLibraryFunction function1 = lib.Lookup(1);
+ TLibraryFunction function2 = lib.Lookup(2);
+ TLibraryFunction function3 = lib.Lookup(3);
+
+ //cast the function pointer f to a function of type void with two arguments
+ typedef void (*TConvertFromUnicodeL)(TDes8&, const TDesC16&);
+ TConvertFromUnicodeL aConvertFromUnicodeL = reinterpret_cast <TConvertFromUnicodeL> (function1);
+
+ typedef void (*TConvertToUnicodeL)(TDes16&, const TDesC8&);
+ TConvertToUnicodeL aConvertToUnicodeL = reinterpret_cast <TConvertToUnicodeL> (function2);
+
+ typedef TBool (*TIsLegalShortNameCharacter)(TUint);
+ TIsLegalShortNameCharacter aIsLegalShortNameCharacter = reinterpret_cast <TIsLegalShortNameCharacter> (function3);
+
+ // from Test Analysis:
+ // p1: 0x40 -> 0x40
+ // p2: 0x24 -> 0x24
+ // p3: 0x706C -> 0xECE1
+ // p4: 0x4E96 -> 0x8181
+ // p5: 0x20AC -> 0xA2E3
+ // p6: 0x3622 -> 0x8230A730, 0x060C -> 0x81318132
+ // p7: 0x201AD (0xD840 0xDDAD) -> 0x9532AD35
+ // p10-p15: N/A
+ // p20-p22: N/A
+ // p30: 0x32FF -> 0x8139D633
+ // p31: 0x10500 (0xD801 0xDD00) -> 0x90318330
+ // 0xFFFF -> 0x8431A439
+ _LIT16(Uni_1, "\x0040\xD840\x0024\x060C\x706C\x4E96\x20AC\x3622\xD840\xDDAD\x32FF\xD801\xDD00\xDC00\xFFFF");
+ _LIT8(CP54936_1, "\x40\x5F\x24\x81\x31\x81\x32\xEC\xE1\x81\x81\xA2\xE3\x82\x30\xA7\x30\x95\x32\xAD\x35\x81\x39\xD6\x33\x90\x31\x83\x30\x5F\x84\x31\xA4\x39");
+
+ TBuf8<200> foreign1;
+ TBuf16<200> unicode2;
+
+ const TDesC16& unicode1(Uni_1);
+ test.Printf(_L("source: ")); TestOut(unicode1); test.Printf(_L("\n"));
+ test.Printf(_L("expect: ")); TestOut(CP54936_1); test.Printf(_L("\n"));
+ //TRAPD(err, (*aConvertFromUnicodeL)(foreign1, unicode1));
+ (*aConvertFromUnicodeL)(foreign1, unicode1); //testing conversion from Unicode
+ test.Printf(_L("result: ")); TestOut(foreign1); test.Printf(_L("\n"));
+ TInt error = foreign1.Compare(CP54936_1);
+ test(error==0);
+ foreign1.Zero();
+
+ // from Test Analysis:
+ // p1: 0x40
+ // p2: 0x24
+ // p3: 0x706C <- 0xECE1
+ // p4: 0x4E96 <- 0x8181
+ // p5: 0x20AC <- 0xA2E3
+ // p6: 0x3622 <- 0x8230A730, 0x060C <- 0x81318132
+ // p7: 0x201AD (0xD840 0xDDAD) <- 0x9532AD35
+ // p10: //0x0E -> 0xFFFD
+ // p11: //0xA0 -> 0xFFFD
+ // p12: 0xA1A0 -> 0xE525
+ // p13: 0xA07F -> 0xFFFD
+ // p14: 0x95328230 -> 0x1FFFA (0xD83F 0xDFFA) //0xFFFD
+ // p15: 0x8130813A -> 0xFFFD
+ // p20-p22: N/A
+ // p30-p31: N/A
+ _LIT16(Uni_2, "\x0040\x0024\x706C\x4E96\x20AC\x3622\x060C\xD840\xDDAD\xE525\xFFFD\xD83F\xDFFA\xFFFD");
+ _LIT8(CP54936_2, "\x40\x24\xEC\xE1\x81\x81\xA2\xE3\x82\x30\xA7\x30\x81\x31\x81\x32\x95\x32\xAD\x35\xA1\xA0\xA0\x7F\x95\x32\x82\x30\x81\x30\x81\x3A");
+
+ const TDesC8& foreign2(CP54936_2);
+ test.Printf(_L("source: ")); TestOut(foreign2); test.Printf(_L("\n"));
+ test.Printf(_L("expect: ")); TestOut(Uni_2); test.Printf(_L("\n"));
+ //TRAP(err, (*aConvertToUnicodeL)(unicode2,foreign2));
+ (*aConvertToUnicodeL)(unicode2,foreign2);//); //testing conversion to Unicode
+ test.Printf(_L("result: ")); TestOut(unicode2); test.Printf(_L("\n"));
+ error = unicode2.Compare(Uni_2);
+ test(error==0);
+ unicode2.Zero();
+
+
+ //testing for legal short name character
+ TInt result = (*aIsLegalShortNameCharacter)(0x005F); //testing for existent character
+ test(result==1);
+ result = (*aIsLegalShortNameCharacter)(0x003F); //testing for illegal character
+ test(result==0);
+ result = (*aIsLegalShortNameCharacter)(0x2999);
+ test(result==1);
+ result = (*aIsLegalShortNameCharacter)(0x4E02); //testing for a double byte character
+ test(result==1);
+
+ lib.Close();
+ }
+
+/**
+@SYMTestCaseID SYSLIB-FATCHARSETCONV-CT-1847-0001
+@SYMTestCaseDesc Tests API behaviours of UnicodeConv class as part of INC090073
+@SYMTestPriority High
+@SYMTestActions Tests for correct character conversion on certain chinese characters for CP936
+@SYMTestExpectedResults Test must not fail
+*/
+void TestINC090073()
+ {
+ test.Next(_L(" @SYMTestCaseID:SYSLIB-FATCHARSETCONV-CT-1847-0001 "));
+ _LIT16(unicode, "\x7CCD\x74EF\x8026\x8F8F\x94F3\x7633\x6DFC\x9785\x7F81\x7A37\x61A9\x80B1\x86A3\x89E5\x80F2\x9B48\x9E47\x6C19\x7B71\x946B\x6B46\x6615");
+ _LIT8(CP932Code, "\xF4\xD9\xEA\xB1\xF1\xEE\xEA\xA3\xEF\xA5\xF1\xAC\xED\xB5\xF7\xB1\xEE\xBF\xF0\xA2\xED\xAC\xEB\xC5\xF2\xBC\xF6\xA1\xEB\xDC\xF7\xCC\xF0\xC2\xEB\xAF\xF3\xE3\xF6\xCE\xEC\xA7\xEA\xBF");
+
+ RLibrary lib;
+
+ const TUidType serverUid(KNullUid,KNullUid,KPluginUid);
+ // load the dll
+ TInt returnValue = lib.Load(KName,serverUid);
+ test(returnValue==0);
+
+ // get a pointer to the specified ordinal function and call it
+ TLibraryFunction function1 = lib.Lookup(1);
+
+
+ //cast the function pointer f to a function of type void with two arguments
+ typedef void (*TConvertFromUnicodeL)(TDes8&, const TDesC16&);
+ TConvertFromUnicodeL aConvertFromUnicodeL = reinterpret_cast <TConvertFromUnicodeL> (function1);
+
+ TBuf8<50> foreign1;
+
+ foreign1.Zero();
+ const TDesC16& unicode1(unicode);
+ TRAPD(err,(*aConvertFromUnicodeL)(foreign1, unicode1)); //testing conversion from Unicode
+ test(err==0);
+ TInt error = foreign1.Compare(CP932Code);
+ test(error==0);
+ foreign1.Zero();
+
+ lib.Close();
+ }
+
+void OOMTest()
+ {
+ test.Next(_L("OOM testing"));
+ TInt err, tryCount = 0;
+ do
+ {
+ __UHEAP_MARK;
+ // find out the number of open handles
+ TInt startProcessHandleCount;
+ TInt startThreadHandleCount;
+ RThread().HandleCount(startProcessHandleCount, startThreadHandleCount);
+
+ // Setting Heap failure for OOM test
+ __UHEAP_SETFAIL(RHeap::EDeterministic, ++tryCount);
+
+ TRAP(err,Test());
+
+ __UHEAP_SETFAIL(RHeap::ENone, 0);
+
+ // check that no handles have leaked
+ TInt endProcessHandleCount;
+ TInt endThreadHandleCount;
+ RThread().HandleCount(endProcessHandleCount, endThreadHandleCount);
+
+ test(startProcessHandleCount == endProcessHandleCount);
+ test(startThreadHandleCount == endThreadHandleCount);
+
+ __UHEAP_MARKEND;
+ }while (err == KErrNoMemory);
+
+ test(err == KErrNone);
+ test.Printf(_L("- server succeeded at heap failure rate of %i\n"), tryCount);
+ }
+
+
+const TInt MaxCount = 10000; // iteration number for performance tests
+
+// cp54936 should be faster than cp936
+_LIT(KName936,"CP936");
+const TUid KPluginUid936={0x10206A91};
+void PerformanceTest1()
+ {
+ test.Next(_L("Performance test 1 (comparing with cp936)"));
+ RLibrary lib936;
+ RLibrary lib54936;
+
+ const TUidType serverUid936(KNullUid,KNullUid,KPluginUid936);
+ const TUidType serverUid54936(KNullUid,KNullUid,KPluginUid);
+
+ // load the dll
+ TInt returnValue = lib936.Load(KName936,serverUid936);
+ test(returnValue==0);
+ TInt returnValue2 = lib54936.Load(KName,serverUid54936);
+ test(returnValue2==0);
+
+ // get a pointer to the specified ordinal function and call it
+ TLibraryFunction function9361 = lib936.Lookup(1);
+ TLibraryFunction function9362 = lib936.Lookup(2);
+ TLibraryFunction function9363 = lib936.Lookup(3);
+ TLibraryFunction function549361 = lib54936.Lookup(1);
+ TLibraryFunction function549362 = lib54936.Lookup(2);
+ TLibraryFunction function549363 = lib54936.Lookup(3);
+
+ //cast the function pointer f to a function of type void with two arguments
+ typedef void (*TConvertFromUnicodeL)(TDes8&, const TDesC16&);
+ TConvertFromUnicodeL aConvertFromUnicode936L = reinterpret_cast <TConvertFromUnicodeL> (function9361);
+ TConvertFromUnicodeL aConvertFromUnicode54936L = reinterpret_cast <TConvertFromUnicodeL> (function549361);
+
+ typedef void (*TConvertToUnicodeL)(TDes16&, const TDesC8&);
+ TConvertToUnicodeL aConvertToUnicode936L = reinterpret_cast <TConvertToUnicodeL> (function9362);
+ TConvertToUnicodeL aConvertToUnicode54936L = reinterpret_cast <TConvertToUnicodeL> (function549362);
+
+ // timer
+ TInt count;
+ TChar res2;
+ TBuf<256> msg;
+ TInt fastTimerFreq;
+ HAL::Get(HALData::EFastCounterFrequency, fastTimerFreq);
+ TReal ticksPerMicroSec = 1.0E-6 * fastTimerFreq;
+ TUint prevTime;
+ TUint timeDiff;
+ TReal64 fsSessionMicroSecs;
+
+ _LIT16(Uni_1, "\x0053\x0059\x004D\x3125\x3122\x9673\xFA29");
+ _LIT8(CP54936_1, "\x53\x59\x4D\xA8\xE5\xA8\xE2\xEA\x90\xFE\x4F");
+ TBuf8<20> foreign1;
+ TBuf16<20> unicode2;
+ const TDesC16& unicode1(Uni_1);
+ TInt error;
+
+//////////////////////////////////////////////////////////////////////////////
+//////////////////////////////////////////////////////////////////////////////
+ // 1, unicode -> 936
+ // test result: 1448 ms for 100000 iterations
+ test.Printf(_L("unicode --> 936:\n"));
+ test.Printf(_L(" source: ")); TestOut(unicode1); test.Printf(_L("\n"));
+ test.Printf(_L(" expect: ")); TestOut(CP54936_1); test.Printf(_L("\n"));
+ prevTime = User::FastCounter();
+ for (count=0; count<MaxCount; count++)
+ {
+ foreign1.Zero();
+ (*aConvertFromUnicode936L)(foreign1, unicode1);
+ }
+ timeDiff = User::FastCounter() - prevTime;
+ fsSessionMicroSecs = timeDiff / (ticksPerMicroSec);
+ msg.Format(_L(" %10.2lf us, "), fsSessionMicroSecs);
+ test.Printf(_L(" result: ")); TestOut(foreign1); test.Printf(_L("\n"));
+ test.Printf(msg);
+ error = foreign1.Compare(CP54936_1);
+ test(error==0);
+ foreign1.Zero();
+ test.Printf(_L("\n"));
+
+ // 2, unicode -> 54936
+ // test result: 44 ms for 100000 iterations
+ test.Printf(_L("unicode --> 54936:\n"));
+ test.Printf(_L(" source: ")); TestOut(unicode1); test.Printf(_L("\n"));
+ test.Printf(_L(" expect: ")); TestOut(CP54936_1); test.Printf(_L("\n"));
+ prevTime = User::FastCounter();
+ for (count=0; count<MaxCount; count++)
+ {
+ foreign1.Zero();
+ (*aConvertFromUnicode54936L)(foreign1, unicode1);
+ }
+ timeDiff = User::FastCounter() - prevTime;
+ fsSessionMicroSecs = timeDiff / (ticksPerMicroSec);
+ msg.Format(_L(" %10.2lf us, "), fsSessionMicroSecs);
+ test.Printf(_L(" result: ")); TestOut(foreign1); test.Printf(_L("\n"));
+ test.Printf(msg);
+ error = foreign1.Compare(CP54936_1);
+ test(error==0);
+ foreign1.Zero();
+ test.Printf(_L("\n"));
+
+//////////////////////////////////////////////////////////////////////////////
+//////////////////////////////////////////////////////////////////////////////
+ _LIT16(Uni_2, "\x0032\xFFFD\x7FB1\x0032\xFFFD\x7FB1\x7FB1");
+ _LIT8(CP54936_2, "\x32\xC1\x7F\xC1\x7E\x32\xC1\x7F\xC1\x7E\xC1\x7E");
+ const TDesC8& foreign2(CP54936_2);
+
+ // 3, 936 -> unicode
+ // test result: 89 ms for 100000 iterations
+ test.Printf(_L("936 ---> unicode:\n"));
+ test.Printf(_L(" source: ")); TestOut(foreign2); test.Printf(_L("\n"));
+ test.Printf(_L(" expect: ")); TestOut(Uni_2); test.Printf(_L("\n"));
+ prevTime = User::FastCounter();
+ for (count=0; count<MaxCount; count++)
+ {
+ unicode2.Zero();
+ (*aConvertToUnicode936L)(unicode2,foreign2);
+ }
+ timeDiff = User::FastCounter() - prevTime;
+ fsSessionMicroSecs = timeDiff / (ticksPerMicroSec);
+ msg.Format(_L(" %10.2lf us, "), fsSessionMicroSecs);
+ test.Printf(_L(" result: ")); TestOut(unicode2); test.Printf(_L("\n"));
+ test.Printf(msg);
+ error = unicode2.Compare(Uni_2);
+ test(error==0);
+ unicode2.Zero();
+ test.Printf(_L("\n"));
+
+ // 4, 54936 -> unicode
+ // test result: 36 ms for 100000 iterations
+ test.Printf(_L("54936 ---> unicode:\n"));
+ test.Printf(_L(" source: ")); TestOut(foreign2); test.Printf(_L("\n"));
+ test.Printf(_L(" expect: ")); TestOut(Uni_2); test.Printf(_L("\n"));
+ prevTime = User::FastCounter();
+ for (count=0; count<MaxCount; count++)
+ {
+ unicode2.Zero();
+ (*aConvertToUnicode54936L)(unicode2,foreign2);
+ }
+ timeDiff = User::FastCounter() - prevTime;
+ fsSessionMicroSecs = timeDiff / (ticksPerMicroSec);
+ msg.Format(_L(" %10.2lf us, "), fsSessionMicroSecs);
+ test.Printf(_L(" result: ")); TestOut(unicode2); test.Printf(_L("\n"));
+ test.Printf(msg);
+ error = unicode2.Compare(Uni_2);
+ test(error==0);
+ unicode2.Zero();
+ test.Printf(_L("\n"));
+
+ lib936.Close();
+ lib54936.Close();
+
+// test.Printf(_L("Press any key...\n"));
+// test.Getch();
+ }
+
+
+// performance when converting mixed data.
+// just for reference.
+// ideally, the test result should be similar to that in PerformanceTest1()
+void PerformanceTest2()
+ {
+ test.Next(_L("Performance test 2 (reference)"));
+ RLibrary lib54936;
+ const TUidType serverUid54936(KNullUid,KNullUid,KPluginUid);
+
+ // load the dll
+ TInt returnValue2 = lib54936.Load(KName,serverUid54936);
+ test(returnValue2==0);
+
+ // get a pointer to the specified ordinal function and call it
+ TLibraryFunction function549361 = lib54936.Lookup(1);
+ TLibraryFunction function549362 = lib54936.Lookup(2);
+ TLibraryFunction function549363 = lib54936.Lookup(3);
+
+ //cast the function pointer f to a function of type void with two arguments
+ typedef void (*TConvertFromUnicodeL)(TDes8&, const TDesC16&);
+ TConvertFromUnicodeL aConvertFromUnicode54936L = reinterpret_cast <TConvertFromUnicodeL> (function549361);
+
+ typedef void (*TConvertToUnicodeL)(TDes16&, const TDesC8&);
+ TConvertToUnicodeL aConvertToUnicode54936L = reinterpret_cast <TConvertToUnicodeL> (function549362);
+
+ // timer
+ TInt count;
+ TBuf<256> msg;
+ TInt fastTimerFreq;
+ HAL::Get(HALData::EFastCounterFrequency, fastTimerFreq);
+ TReal ticksPerMicroSec = 1.0E-6 * fastTimerFreq;
+ TUint prevTime;
+ TUint timeDiff;
+ TReal64 fsSessionMicroSecs;
+
+//////////////////////////////////////////////////////////////////////////////
+//////////////////////////////////////////////////////////////////////////////
+ _LIT16(Uni_1, "\x0053\x0059\x004D\x3125\x3122\x9673\xFA29\x060C\xD840\xDC00");
+ _LIT8(CP54936_1, "\x53\x59\x4D\xA8\xE5\xA8\xE2\xEA\x90\xFE\x4F\x81\x31\x81\x32\x95\x32\x82\x36");
+ TBuf8<200> foreign1;
+ TBuf16<200> unicode2;
+ const TDesC16& unicode1(Uni_1);
+ TInt error;
+
+ // 2, unicode -> 54936
+ // test result: 130 ms for 100000 iterations (44 ms if one huge table for BMP characters)
+ test.Printf(_L("unicode --> 54936:\n"));
+ test.Printf(_L(" source: ")); TestOut(unicode1); test.Printf(_L("\n"));
+ test.Printf(_L(" expect: ")); TestOut(CP54936_1); test.Printf(_L("\n"));
+ prevTime = User::FastCounter();
+ for (count=0; count<MaxCount; count++)
+ {
+ foreign1.Zero();
+ (*aConvertFromUnicode54936L)(foreign1, unicode1);
+ }
+ timeDiff = User::FastCounter() - prevTime;
+ fsSessionMicroSecs = timeDiff / (ticksPerMicroSec);
+ msg.Format(_L(" %10.2lf us, "), fsSessionMicroSecs);
+ test.Printf(_L(" result: ")); TestOut(foreign1); test.Printf(_L("\n"));
+ test.Printf(msg);
+ error = foreign1.Compare(CP54936_1);
+ test(error==0);
+ foreign1.Zero();
+ test.Printf(_L("\n"));
+
+//////////////////////////////////////////////////////////////////////////////
+//////////////////////////////////////////////////////////////////////////////
+ _LIT16(Uni_2, "\x0032\x20AC\xFFFD\x7FB1\x47BB\xD840\xDC00");
+ _LIT8(CP54936_2, "\x32\xA2\xE3\xC1\x7F\xC1\x7E\x82\x33\xED\x33\x95\x32\x82\x36");
+ const TDesC8& foreign2(CP54936_2);
+
+ // 4, 54936 -> unicode
+ // test result: 36 ms for 100000 iterations
+ test.Printf(_L("54936 ---> unicode:\n"));
+ test.Printf(_L(" source: ")); TestOut(foreign2); test.Printf(_L("\n"));
+ test.Printf(_L(" expect: ")); TestOut(Uni_2); test.Printf(_L("\n"));
+ prevTime = User::FastCounter();
+ for (count=0; count<MaxCount; count++)
+ {
+ unicode2.Zero();
+ (*aConvertToUnicode54936L)(unicode2,foreign2);
+ }
+ timeDiff = User::FastCounter() - prevTime;
+ fsSessionMicroSecs = timeDiff / (ticksPerMicroSec);
+ msg.Format(_L(" %10.2lf us, "), fsSessionMicroSecs);
+ test.Printf(_L(" result: ")); TestOut(unicode2); test.Printf(_L("\n"));
+ test.Printf(msg);
+ error = unicode2.Compare(Uni_2);
+ test(error==0);
+ unicode2.Zero();
+ test.Printf(_L("\n"));
+
+ lib54936.Close();
+
+// test.Printf(_L("Press any key...\n"));
+// test.Getch();
+ }
+
+/**
+@SYMTestCaseID TI18N-FATCHARCONV-CIT-4001
+@SYMTestCaseDesc Check GB18030 support
+@SYMTestPriority High
+@SYMTestActions 1. Get one-byte Unicode codepoint
+ 2. Convert to/from GB18030 to/from Unicode
+ 3. Get two-byte Unicode codepoint
+ 4. Convert to/from GB18030 to/from Unicode
+ 5. Get four-byte Unicode codepoint
+ 6. Convert to/from GB18030 to/from Unicode
+@SYMTestExpectedResults No side effect
+@SYMREQ REQ12067
+*/
+LOCAL_C void TestConversion( const TDesC16& aUnicode, const TDesC8& a54936, TBool aZero1=ETrue, TBool aZero2=ETrue )
+{
+ test.Next(_L(" @SYMTestCaseID:SYSLIB-FATCHARSETCONV-CT-1778 "));
+ RLibrary lib;
+
+ const TUidType serverUid(KNullUid,KNullUid,KPluginUid);
+ // load the dll
+ TInt returnValue = lib.Load(KName,serverUid);
+ test(returnValue==0);
+
+ // get a pointer to the specified ordinal function and call it
+ TLibraryFunction function1 = lib.Lookup(1);
+ TLibraryFunction function2 = lib.Lookup(2);
+ TLibraryFunction function3 = lib.Lookup(3);
+
+ //cast the function pointer f to a function of type void with two arguments
+ typedef void (*TConvertFromUnicodeL)(TDes8&, const TDesC16&);
+ TConvertFromUnicodeL aConvertFromUnicodeL = reinterpret_cast <TConvertFromUnicodeL> (function1);
+
+ typedef void (*TConvertToUnicodeL)(TDes16&, const TDesC8&);
+ TConvertToUnicodeL aConvertToUnicodeL = reinterpret_cast <TConvertToUnicodeL> (function2);
+
+ // testing conversion from Unicode
+ TBuf8<200> generated54936;
+ test.Printf(_L("source: "));
+ TestOut(aUnicode);
+ test.Printf(_L("\n"));
+ test.Printf(_L("expect: "));
+ TestOut(a54936);
+ test.Printf(_L("\n"));
+ (*aConvertFromUnicodeL)(generated54936, aUnicode);
+ test.Printf(_L("result: "));
+ TestOut(generated54936);
+ test.Printf(_L("\n"));
+ TInt error = generated54936.Compare(a54936);
+ if ( aZero1 )
+ {
+ test(error==0);
+ }
+ else
+ {
+ test(error!=0);
+ }
+
+ // testing conversion to Unicode
+ TBuf16<200> generatedUnicode;
+ test.Printf(_L("source: "));
+ TestOut(a54936);
+ test.Printf(_L("\n"));
+ test.Printf(_L("expect: "));
+ TestOut(aUnicode);
+ test.Printf(_L("\n"));
+ (*aConvertToUnicodeL)(generatedUnicode,a54936);
+ test.Printf(_L("result: "));
+ TestOut(generatedUnicode);
+ test.Printf(_L("\n"));
+ error = generatedUnicode.Compare(aUnicode);
+ if ( aZero2 )
+ {
+ test(error==0);
+ }
+ else
+ {
+ test(error!=0);
+ }
+
+ lib.Close();
+}
+
+
+/**
+@SYMTestCaseID TI18N-CHARCONV-CT-
+@SYMTestCaseDesc Check GB18030 support
+@SYMTestPriority High
+@SYMTestActions 1. Get one-byte Unicode codepoint
+ 2. Convert to/from GB18030 to/from Unicode
+ 3. Get two-byte Unicode codepoint
+ 4. Convert to/from GB18030 to/from Unicode
+ 5. Get four-byte Unicode codepoint
+ 6. Convert to/from GB18030 to/from Unicode
+@SYMTestExpectedResults No side effect
+@SYMREQ REQ12067
+*/
+LOCAL_C void TestGbConversion()
+{
+ // Test() function covers GB 1,2,4 bytes
+ // one-byte
+ // border 0x80
+ _LIT16(Uni_0, "\x0000");
+ _LIT8(CP54936_0, "\x00");
+ TestConversion( Uni_0, CP54936_0 );
+
+ _LIT16(Uni_1, "\x0079");
+ _LIT8(CP54936_1, "\x79");
+ TestConversion( Uni_1, CP54936_1 );
+
+ _LIT16(Uni_2, "\x0080");
+ _LIT8(CP54936_2, "\x81\x30\x81\x30");
+ TestConversion( Uni_2, CP54936_2 );
+
+ _LIT16(Uni_3, "\x0081");
+ _LIT8(CP54936_3, "\x81\x30\x81\x31");
+ TestConversion( Uni_3, CP54936_3 );
+
+ _LIT16(Uni_4, "\x00fe");
+ _LIT8(CP54936_4, "\x81\x30\x8B\x36");
+ TestConversion( Uni_4, CP54936_4 );
+
+ _LIT16(Uni_5, "\x00ff");
+ _LIT8(CP54936_5, "\x81\x30\x8B\x37");
+ TestConversion( Uni_5, CP54936_5 );
+
+ // two-byte
+ _LIT16(Uni_6, "\x0100");
+ _LIT8(CP54936_6, "\x81\x30\x8B\x38");
+ TestConversion( Uni_6, CP54936_6 );
+
+ _LIT16(Uni_7, "\x0101");
+ _LIT8(CP54936_7, "\xA8\xA1");
+ TestConversion( Uni_7, CP54936_7 );
+
+ _LIT16(Uni_8, "\x0ffe");
+ _LIT8(CP54936_8, "\x81\x33\x83\x38");
+ TestConversion( Uni_8, CP54936_8 );
+
+ _LIT16(Uni_9, "\x0fff");
+ _LIT8(CP54936_9, "\x81\x33\x83\x39");
+ TestConversion( Uni_9, CP54936_9 );
+
+ _LIT16(Uni_10, "\x1000");
+ _LIT8(CP54936_10, "\x81\x33\x84\x30");
+ TestConversion( Uni_10, CP54936_10 );
+
+ _LIT16(Uni_11, "\x1001");
+ _LIT8(CP54936_11, "\x81\x33\x84\x31");
+ TestConversion( Uni_11, CP54936_11 );
+
+ _LIT16(Uni_12, "\xfffe");
+ _LIT8(CP54936_12, "\x84\x31\xA4\x38");
+ TestConversion( Uni_12, CP54936_12 );
+
+ _LIT16(Uni_13, "\xffff");
+ _LIT8(CP54936_13, "\x84\x31\xA4\x39");
+ TestConversion( Uni_13, CP54936_13 );
+
+ // four-byte
+ _LIT16(Uni_14, "\xd840\xdc00");
+ _LIT8(CP54936_14, "\x95\x32\x82\x36");
+ TestConversion( Uni_14, CP54936_14 );
+
+ _LIT16(Uni_15, "\xd840\xdc01");
+ _LIT8(CP54936_15, "\x95\x32\x82\x37");
+ TestConversion( Uni_15, CP54936_15 );
+
+ _LIT16(Uni_16, "\xD87F\xdffe");
+ _LIT8(CP54936_16, "\x9a\x34\x84\x30");
+ TestConversion( Uni_16, CP54936_16 );
+
+ _LIT16(Uni_17, "\xD87F\xdfff");
+ _LIT8(CP54936_17, "\x9a\x34\x84\x31");
+ TestConversion( Uni_17, CP54936_17 );
+
+ // 4-byte gb
+ _LIT16(Uni_18, "\xd840\xddad");
+ _LIT8(CP54936_18, "\x95\x32\xAD\x35");
+ TestConversion( Uni_18, CP54936_18 );
+
+ _LIT16(Uni_19, "\xd801\xdd00");
+ _LIT8(CP54936_19, "\x90\x31\x83\x30");
+ TestConversion( Uni_19, CP54936_19 );
+}
+
+
+/**
+@SYMTestCaseID TI18N-CHARCONV-CT-
+@SYMTestCaseDesc Test FAT short name legal character
+@SYMTestPriority High
+@SYMTestActions 1. Get one-byte Unicode codepoint
+ 2. Check if it's legal short name character
+ 3. Get two-byte Unicode codepoint
+ 4. Check if it's legal short name character
+ 5. Get four-byte Unicode codepoint
+ 6. Check if it's legal short name character
+@SYMTestExpectedResults No side effect
+@SYMREQ REQ12067
+*/
+LOCAL_C void TestShortNameCharacter()
+{
+ test.Next(_L(" @SYMTestCaseID:SYSLIB-FATCHARSETCONV-CT-1778 "));
+ RLibrary lib;
+
+ const TUidType serverUid(KNullUid,KNullUid,KPluginUid);
+ // load the dll
+ TInt returnValue = lib.Load(KName,serverUid);
+ test(returnValue==0);
+
+ // get a pointer to the specified ordinal function and call it
+ TLibraryFunction function1 = lib.Lookup(1);
+ TLibraryFunction function2 = lib.Lookup(2);
+ TLibraryFunction function3 = lib.Lookup(3);
+
+ typedef TBool (*TIsLegalShortNameCharacter)(TUint);
+ TIsLegalShortNameCharacter aIsLegalShortNameCharacter = reinterpret_cast <TIsLegalShortNameCharacter> (function3);
+
+ // testing for legal short name character
+ // one-byte unicode
+ // 0x20 is space
+ TInt result = (*aIsLegalShortNameCharacter)(0x0019);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x0020);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x0021);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x005F);
+ test(result==1);
+
+ // 0x80 is ascii border
+ result = (*aIsLegalShortNameCharacter)(0x0079);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x0080);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x0081);
+ test(result==1);
+
+ // testing for illegal character
+ result = (*aIsLegalShortNameCharacter)(0x003F);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x22);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x2A);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x2B);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x2C);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x2F);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x3A);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x3B);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x3C);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x3D);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x3E);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x5B);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x5C);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x5D);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0x7C);
+ test(result==0);
+
+ // two-byte unicode
+ result = (*aIsLegalShortNameCharacter)(0x1000);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x1001);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x2999); //testing for non-existent character
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x4E02); //testing for a double byte character
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0xfffe);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0xffff);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0xd7ff);
+ test(result==1);
+
+ // surrogate part
+ result = (*aIsLegalShortNameCharacter)(0xd800);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0xdfff);
+ test(result==0);
+
+ result = (*aIsLegalShortNameCharacter)(0xe000);
+ test(result==1);
+
+ // four-byte unicode
+ result = (*aIsLegalShortNameCharacter)(0x10000);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x10001);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x10fffe);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x10ffff);
+ test(result==1);
+
+ result = (*aIsLegalShortNameCharacter)(0x110000);
+ test(result==0);
+
+ lib.Close();
+}
+
+
+LOCAL_C void DoE32MainL()
+ {
+ __UHEAP_MARK;
+
+ TestGbConversion();
+ TestShortNameCharacter();
+ Test();
+ TestINC090073();
+ OOMTest();
+ PerformanceTest1();
+ PerformanceTest2();
+
+ __UHEAP_MARKEND;
+ }
+
+GLDEF_C TInt E32Main()
+ {
+ __UHEAP_MARK;
+
+ test.Title();
+ test.Start(_L("CP54936 test..."));
+
+ CTrapCleanup* trapCleanup=CTrapCleanup::New();
+ TRAPD(error, DoE32MainL());
+ test(error==KErrNone);
+
+ delete trapCleanup;
+
+ test.End();
+ test.Close();
+
+ __UHEAP_MARKEND;
+ return error;
+ }