sl@0: /* sl@0: * Copyright (c) 2000-2010 Nokia Corporation and/or its subsidiary(-ies). sl@0: * All rights reserved. sl@0: * This component and the accompanying materials are made available sl@0: * under the terms of "Eclipse Public License v1.0" sl@0: * which accompanies this distribution, and is available sl@0: * at the URL "http://www.eclipse.org/legal/epl-v10.html". sl@0: * sl@0: * Initial Contributors: sl@0: * Nokia Corporation - initial contribution. sl@0: * sl@0: * Contributors: sl@0: * sl@0: * Description: sl@0: * sl@0: */ sl@0: sl@0: #include sl@0: #include sl@0: #include sl@0: #include sl@0: #include "t_eucjpdirectmap.h" sl@0: sl@0: #define test(cond) \ sl@0: { \ sl@0: TBool __bb = (cond); \ sl@0: TEST(__bb); \ sl@0: if (!__bb) \ sl@0: { \ sl@0: ERR_PRINTF1(_L("ERROR: Test Failed")); \ sl@0: User::Leave(1); \ sl@0: } \ sl@0: } sl@0: sl@0: const TInt KBufferLength=100; sl@0: sl@0: void CT_EUCJPDIRECTMAP::TestTruncatedConversionFromUnicodeToEucJpDirectmap(CCnvCharacterSetConverter& aCharacterSetConverter, const TDesC16& aOriginalUnicode) sl@0: { sl@0: for (TInt i=aOriginalUnicode.Length(); i>=0; --i) sl@0: { sl@0: TBuf8 generatedEucJpDirectmap; sl@0: const TInt returnValue=aCharacterSetConverter.ConvertFromUnicode(generatedEucJpDirectmap, aOriginalUnicode.Left(i)); sl@0: test(returnValue>=0); sl@0: TBuf8 generatedsecondPartOfEucJpDirectmap; sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedsecondPartOfEucJpDirectmap, aOriginalUnicode.Mid(i-returnValue))==0); sl@0: generatedEucJpDirectmap.Append(generatedsecondPartOfEucJpDirectmap); sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TBuf16 generatedUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedUnicode, generatedEucJpDirectmap, state)==0); sl@0: test(generatedUnicode==aOriginalUnicode); sl@0: } sl@0: } sl@0: sl@0: void CT_EUCJPDIRECTMAP::TestSplittingConvertingFromUnicodeToEucJpDirectmap(CCnvCharacterSetConverter& aCharacterSetConverter, TInt aMaximumLengthLowerLimit, TInt aMaximumLengthUpperLimit, TInt aExpectedNumberOfUnicodeCharactersNotConvertedAtSplit, TInt aExpectedLengthOfFirstPartOfEucJpDirectmap, const TDesC8& aExpectedEucJpDirectmap, const TDesC16& aOriginalUnicode) sl@0: { sl@0: test(aMaximumLengthLowerLimit<=aMaximumLengthUpperLimit); sl@0: test(aMaximumLengthUpperLimit<=KBufferLength); sl@0: TUint8 eucJpDirectmapBuffer[KBufferLength]; sl@0: for (TInt i=aMaximumLengthLowerLimit; i<=aMaximumLengthUpperLimit; ++i) sl@0: { sl@0: TPtr8 generatedFirstPartOfEucJpDirectmap(eucJpDirectmapBuffer, i); sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedFirstPartOfEucJpDirectmap, aOriginalUnicode)==aExpectedNumberOfUnicodeCharactersNotConvertedAtSplit); sl@0: test(generatedFirstPartOfEucJpDirectmap==aExpectedEucJpDirectmap.Left(aExpectedLengthOfFirstPartOfEucJpDirectmap)); sl@0: TBuf8 generatedSecondPartOfEucJpDirectmap; sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedSecondPartOfEucJpDirectmap, aOriginalUnicode.Right(aExpectedNumberOfUnicodeCharactersNotConvertedAtSplit))==0); sl@0: test(generatedSecondPartOfEucJpDirectmap==aExpectedEucJpDirectmap.Mid(aExpectedLengthOfFirstPartOfEucJpDirectmap)); sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TBuf16 generatedUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedUnicode, generatedFirstPartOfEucJpDirectmap, state)==0); sl@0: test(state==CCnvCharacterSetConverter::KStateDefault); sl@0: TBuf16 generatedSecondPartOfUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedSecondPartOfUnicode, generatedSecondPartOfEucJpDirectmap, state)==0); sl@0: test(state==CCnvCharacterSetConverter::KStateDefault); sl@0: generatedUnicode.Append(generatedSecondPartOfUnicode); sl@0: test(generatedUnicode==aOriginalUnicode); sl@0: } sl@0: } sl@0: sl@0: void CT_EUCJPDIRECTMAP::TestTruncatedConversionToUnicodeFromEucJpDirectmap(CCnvCharacterSetConverter& aCharacterSetConverter, const TDesC16& aExpectedUnicode, const TDesC8& aOriginalEucJpDirectmap) sl@0: { sl@0: for (TInt i=aOriginalEucJpDirectmap.Length(); i>=3; --i) sl@0: { sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TBuf16 generatedUnicode; sl@0: const TInt returnValue=aCharacterSetConverter.ConvertToUnicode(generatedUnicode, aOriginalEucJpDirectmap.Left(i), state); sl@0: test(returnValue>=0); sl@0: TBuf16 generatedsecondPartOfUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedsecondPartOfUnicode, aOriginalEucJpDirectmap.Mid(i-returnValue), state)==0); sl@0: generatedUnicode.Append(generatedsecondPartOfUnicode); sl@0: test(generatedUnicode==aExpectedUnicode); sl@0: } sl@0: } sl@0: sl@0: void CT_EUCJPDIRECTMAP::TestSplittingConvertingToUnicodeFromEucJpDirectmap(CCnvCharacterSetConverter& aCharacterSetConverter, TInt aMaximumLengthLowerLimit, TInt aMaximumLengthUpperLimit, TInt aExpectedNumberOfEucJpDirectmapBytesNotConvertedAtSplit, TInt aExpectedLengthOfFirstPartOfUnicode, const TDesC16& aExpectedUnicode, const TDesC8& aOriginalEucJpDirectmap) sl@0: { sl@0: test(aMaximumLengthLowerLimit<=aMaximumLengthUpperLimit); sl@0: test(aMaximumLengthUpperLimit<=KBufferLength); sl@0: TUint16 unicodeBuffer[KBufferLength]; sl@0: for (TInt i=aMaximumLengthLowerLimit; i<=aMaximumLengthUpperLimit; ++i) sl@0: { sl@0: TPtr16 generatedFirstPartOfUnicode(unicodeBuffer, i); sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedFirstPartOfUnicode, aOriginalEucJpDirectmap, state)==aExpectedNumberOfEucJpDirectmapBytesNotConvertedAtSplit); sl@0: test(generatedFirstPartOfUnicode==aExpectedUnicode.Left(aExpectedLengthOfFirstPartOfUnicode)); sl@0: test(state==CCnvCharacterSetConverter::KStateDefault); sl@0: TBuf16 generatedSecondPartOfUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedSecondPartOfUnicode, aOriginalEucJpDirectmap.Right(aExpectedNumberOfEucJpDirectmapBytesNotConvertedAtSplit), state)==0); sl@0: test(generatedSecondPartOfUnicode==aExpectedUnicode.Mid(aExpectedLengthOfFirstPartOfUnicode)); sl@0: test(state==CCnvCharacterSetConverter::KStateDefault); sl@0: TBuf8 generatedEucJpDirectmap; sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedEucJpDirectmap, generatedFirstPartOfUnicode)==0); sl@0: TBuf8 generatedSecondPartOfEucJpDirectmap; sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedSecondPartOfEucJpDirectmap, generatedSecondPartOfUnicode)==0); sl@0: generatedEucJpDirectmap.Append(generatedSecondPartOfEucJpDirectmap); sl@0: test(generatedEucJpDirectmap==aOriginalEucJpDirectmap); sl@0: } sl@0: } sl@0: sl@0: void CT_EUCJPDIRECTMAP::TestIsIllFormedEucJpDirectmap(CCnvCharacterSetConverter& aCharacterSetConverter, const TDesC8& aEucJpDirectmap) sl@0: { sl@0: TBuf16<50> generatedUnicode; sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TPtrC8 remainderOfEucJpDirectmap(aEucJpDirectmap); sl@0: TInt lastReturnValue=KMaxTInt; sl@0: FOREVER sl@0: { sl@0: const TInt returnValue=aCharacterSetConverter.ConvertToUnicode(generatedUnicode, remainderOfEucJpDirectmap, state); sl@0: if (returnValue==CCnvCharacterSetConverter::EErrorIllFormedInput) sl@0: { sl@0: break; sl@0: } sl@0: test(returnValue>0); sl@0: test(returnValue* arrayOfCharacterSetsAvailable=CCnvCharacterSetConverter::CreateArrayOfCharacterSetsAvailableLC(fileServerSession); sl@0: INFO_PRINTF1(_L("Available:\n")); sl@0: TInt i; sl@0: for (i=arrayOfCharacterSetsAvailable->Count()-1; i>=0; --i) sl@0: { sl@0: const CCnvCharacterSetConverter::SCharacterSet& charactersSet=(*arrayOfCharacterSetsAvailable)[i]; sl@0: characterSetConverter->PrepareToConvertToOrFromL(charactersSet.Identifier(), *arrayOfCharacterSetsAvailable, fileServerSession); sl@0: TPtrC charactersSetName(charactersSet.Name()); sl@0: if (charactersSet.NameIsFileName()) sl@0: { sl@0: charactersSetName.Set(TParsePtrC(charactersSetName).Name()); sl@0: } sl@0: INFO_PRINTF2(_L(" %S\n"), &charactersSetName); sl@0: } sl@0: INFO_PRINTF1(_L("Testing EUC-JP (DirectMap) conversions ")); sl@0: characterSetConverter->PrepareToConvertToOrFromL(KCharacterSetIdentifierEucJpDirectmap, *arrayOfCharacterSetsAvailable, fileServerSession); sl@0: // sl@0: INFO_PRINTF1(_L("Empty descriptor")); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 0, 10, 0, 0, KNullDesC8, KNullDesC16); sl@0: TestSplittingConvertingToUnicodeFromEucJpDirectmap(*characterSetConverter, 0, 10, 0, 0, KNullDesC16, KNullDesC8); sl@0: INFO_PRINTF1(_L("Testing converting to EUC-JP (DirectMap)")); sl@0: TBuf16<50> originalUnicode; sl@0: originalUnicode.Format(_L16("Some %c%c%c%c%c%c"), 0xff9a, 0xff70, 0x6f22, 0x5b57, 0x5379, 0x5dce); sl@0: const TPtrC8 expectedEucJpDirectmap(_S8("Some \x8e\xda\x8e\xb0\xb4\xc1\xbb\xfa\x8f\xb4\xc1\x8f\xbb\xfa")); sl@0: TestTruncatedConversionFromUnicodeToEucJpDirectmap(*characterSetConverter, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 0, 0, 11, 0, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 1, 1, 10, 1, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 2, 2, 9, 2, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 3, 3, 8, 3, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 4, 4, 7, 4, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 5, 6, 6, 5, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 7, 8, 5, 7, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 9, 10, 4, 9, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 11, 12, 3, 11, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 13, 15, 2, 13, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 16, 18, 1, 16, expectedEucJpDirectmap, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToEucJpDirectmap(*characterSetConverter, 19, 30, 0, 19, expectedEucJpDirectmap, originalUnicode); sl@0: INFO_PRINTF1(_L("Testing converting to Unicode")); sl@0: const TPtrC8 originalEucJpDirectmap(_S8("pool\xbe\xae\xc3\xd3\x8e\xcc\x8e\xdf\x8e\xd9\x8f\xc0\xcd\x8f\xc8\xc5pool\x8e\xcc\x8e\xdf\x8e\xd9\xbe\xae\xc3\xd3\x8f\xc0\xcd\x8f\xc8\xc5\xbe\xae\xc3\xd3pool\x8f\xc0\xcd\x8f\xc8\xc5\x8e\xcc\x8e\xdf\x8e\xd9pool")); sl@0: TBuf16<50> expectedUnicode; sl@0: expectedUnicode.Format(_L16("pool%c%c%c%c%c%c%cpool%c%c%c%c%c%c%c%c%cpool%c%c%c%c%cpool"), 0x5c0f, 0x6c60, 0xff8c, 0xff9f, 0xff99, 0x641e, 0x6f0d, 0xff8c, 0xff9f, 0xff99, 0x5c0f, 0x6c60, 0x641e, 0x6f0d, 0x5c0f, 0x6c60, 0x641e, 0x6f0d, 0xff8c, 0xff9f, 0xff99); sl@0: TestTruncatedConversionToUnicodeFromEucJpDirectmap(*characterSetConverter, expectedUnicode, originalEucJpDirectmap); sl@0: TestTruncatedConversionToUnicodeFromEucJpDirectmap(*characterSetConverter, expectedUnicode.Mid(4, 2), originalEucJpDirectmap.Mid(4, 4)); sl@0: TestTruncatedConversionToUnicodeFromEucJpDirectmap(*characterSetConverter, expectedUnicode.Mid(6, 3), originalEucJpDirectmap.Mid(8, 6)); sl@0: TestTruncatedConversionToUnicodeFromEucJpDirectmap(*characterSetConverter, expectedUnicode.Mid(9, 2), originalEucJpDirectmap.Mid(14, 6)); sl@0: static const TInt numberOfCharactersInEachHomogeneousRun[13]={4, 2, 3, 2, 4, 3, 2, 2, 2, 4, 2, 3, 4}; sl@0: static const TInt numberOfBytesPerCharacterInEachHomogeneousRun[13]={1, 2, 2, 3, 1, 2, 2, 3, 2, 1, 3, 2, 1}; sl@0: TInt e=64; sl@0: TInt u=0; sl@0: for (i=0; i<13; ++i) sl@0: { sl@0: TInt j; sl@0: for (j=0; j expectedUnicodeBackSlash; sl@0: expectedUnicodeBackSlash.Format(_L16("pool%c"), 0x005c); sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TBuf16 generatedUnicodeBackSlash; sl@0: test(characterSetConverter->ConvertToUnicode(generatedUnicodeBackSlash, originalEucJpDirectmapYen, state) == 0); sl@0: test(generatedUnicodeBackSlash==expectedUnicodeBackSlash); sl@0: sl@0: CleanupStack::PopAndDestroy(3); // arrayOfCharacterSetsAvailable and characterSetConverter and fileServerSession sl@0: } sl@0: sl@0: CT_EUCJPDIRECTMAP::CT_EUCJPDIRECTMAP() sl@0: { sl@0: SetTestStepName(KTestStep_T_EUCJPDIRECTMAP); sl@0: } sl@0: sl@0: TVerdict CT_EUCJPDIRECTMAP::doTestStepL() sl@0: { sl@0: SetTestStepResult(EFail); sl@0: sl@0: __UHEAP_MARK; sl@0: TRAPD(error1, DoE32MainL()); sl@0: __UHEAP_MARKEND; sl@0: sl@0: if(error1 == KErrNone) sl@0: { sl@0: SetTestStepResult(EPass); sl@0: } sl@0: sl@0: return TestStepResult(); sl@0: }