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: sl@0: #include sl@0: #include sl@0: #include sl@0: #include sl@0: #include "t_iso2022jp.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: const TInt KNotEnoughBufferLength=17; sl@0: /** sl@0: @SYMTestCaseID SYSLIB-CHARCONV-CT-0522 sl@0: @SYMTestCaseDesc Tests for conversion from Unicode to ISO2022JP sl@0: @SYMTestPriority Medium sl@0: @SYMTestActions Tests for conversion from Unicode to ISO2022JP and back to Unicode sl@0: @SYMTestExpectedResults Test must not fail sl@0: @SYMREQ REQ0000 sl@0: */ sl@0: void CT_ISO2022JP::TestConversionFromUnicodeToIso( sl@0: CCnvCharacterSetConverter& aCharacterSetConverter, sl@0: const TDesC16& aOriginalUnicode) sl@0: { sl@0: INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0522 ")); sl@0: TBuf8 generatedIso2022Jp; sl@0: generatedIso2022Jp.FillZ(KNotEnoughBufferLength); sl@0: const TInt returnValue=aCharacterSetConverter.ConvertFromUnicode(generatedIso2022Jp, aOriginalUnicode); sl@0: test(returnValue>=0); sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TBuf16 generatedUnicode; sl@0: TInt testresult; sl@0: testresult=aCharacterSetConverter.ConvertToUnicode(generatedUnicode, generatedIso2022Jp, state); sl@0: test(testresult==0); sl@0: // test(generatedUnicode==aOriginalUnicode); sl@0: } sl@0: /** sl@0: @SYMTestCaseID SYSLIB-CHARCONV-CT-0523 sl@0: @SYMTestCaseDesc Tests for truncated conversion from Unicode to ISO2022JP sl@0: @SYMTestPriority Medium sl@0: @SYMTestActions Tests for truncated conversion from Unicode to ISO2022JP and back to Unicode sl@0: @SYMTestExpectedResults Test must not fail sl@0: @SYMREQ REQ0000 sl@0: */ sl@0: void CT_ISO2022JP::TestTruncatedConversionFromUnicodeToIso2022Jp( sl@0: CCnvCharacterSetConverter& aCharacterSetConverter, sl@0: const TDesC16& aOriginalUnicode) sl@0: { sl@0: INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0523 ")); sl@0: for (TInt i=aOriginalUnicode.Length(); i>=0; --i) sl@0: { sl@0: TBuf8 generatedIso2022Jp; sl@0: const TInt returnValue=aCharacterSetConverter.ConvertFromUnicode(generatedIso2022Jp, aOriginalUnicode.Left(i)); sl@0: test(returnValue>=0); sl@0: TBuf8 generatedsecondPartOfIso2022Jp; sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedsecondPartOfIso2022Jp, aOriginalUnicode.Mid(i-returnValue))==0); sl@0: generatedIso2022Jp.Append(generatedsecondPartOfIso2022Jp); sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TBuf16 generatedUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedUnicode, generatedIso2022Jp, state)==0); sl@0: test(generatedUnicode==aOriginalUnicode); sl@0: } sl@0: } sl@0: /** sl@0: @SYMTestCaseID SYSLIB-CHARCONV-CT-0524 sl@0: @SYMTestCaseDesc Splitting and converting from Unicode to ISO2022JP test sl@0: @SYMTestPriority Medium sl@0: @SYMTestActions Tests for conversion after splitting, from Unicode to ISO2022JP and back to Unicode sl@0: @SYMTestExpectedResults Test must not fail sl@0: @SYMREQ REQ0000 sl@0: */ sl@0: void CT_ISO2022JP::TestSplittingConvertingFromUnicodeToIso2022Jp( sl@0: CCnvCharacterSetConverter& aCharacterSetConverter, sl@0: TInt aMaximumLengthLowerLimit, sl@0: TInt aMaximumLengthUpperLimit, sl@0: TInt aExpectedNumberOfUnicodeCharactersNotConvertedAtSplit, sl@0: const TDesC8& aExpectedFirstPartOfIso2022Jp, sl@0: const TDesC8& aExpectedSecondPartOfIso2022Jp, sl@0: const TDesC16& aOriginalUnicode) sl@0: { sl@0: INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0524 ")); sl@0: test(aMaximumLengthLowerLimit<=aMaximumLengthUpperLimit); sl@0: test(aMaximumLengthUpperLimit<=KBufferLength); sl@0: TUint8 iso2022JpBuffer[KBufferLength]; sl@0: for (TInt i=aMaximumLengthLowerLimit; i<=aMaximumLengthUpperLimit; ++i) sl@0: { sl@0: TPtr8 generatedFirstPartOfIso2022Jp(iso2022JpBuffer, i); sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedFirstPartOfIso2022Jp, aOriginalUnicode)==aExpectedNumberOfUnicodeCharactersNotConvertedAtSplit); sl@0: test(generatedFirstPartOfIso2022Jp==aExpectedFirstPartOfIso2022Jp); sl@0: TBuf8 generatedSecondPartOfIso2022Jp; sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedSecondPartOfIso2022Jp, aOriginalUnicode.Right(aExpectedNumberOfUnicodeCharactersNotConvertedAtSplit))==0); sl@0: test(generatedSecondPartOfIso2022Jp==aExpectedSecondPartOfIso2022Jp); sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TBuf16 generatedUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedUnicode, generatedFirstPartOfIso2022Jp, state)==0); sl@0: TBuf16 generatedSecondPartOfUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedSecondPartOfUnicode, generatedSecondPartOfIso2022Jp, state)==0); sl@0: generatedUnicode.Append(generatedSecondPartOfUnicode); sl@0: test(generatedUnicode==aOriginalUnicode); sl@0: } sl@0: } sl@0: /** sl@0: @SYMTestCaseID SYSLIB-CHARCONV-CT-0525 sl@0: @SYMTestCaseDesc Tests for truncated conversion from ISO2022JP to Unicode test sl@0: @SYMTestPriority Medium sl@0: @SYMTestActions Tests for truncated conversion from ISO2022JP to Unicode and back to ISO2022JP sl@0: @SYMTestExpectedResults Test must not fail sl@0: @SYMREQ REQ0000 sl@0: */ sl@0: void CT_ISO2022JP::TestTruncatedConversionToUnicodeFromIso2022Jp( sl@0: CCnvCharacterSetConverter& aCharacterSetConverter, sl@0: const TDesC16& aExpectedUnicode, sl@0: const TDesC8& aOriginalIso2022Jp) sl@0: { sl@0: INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0525 ")); sl@0: for (TInt i=aOriginalIso2022Jp.Length(); i>=3; --i) // 3 is the length of ISO-2022-JP's longest escape sequence sl@0: { sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TBuf16 generatedUnicode; sl@0: const TInt returnValue=aCharacterSetConverter.ConvertToUnicode(generatedUnicode, aOriginalIso2022Jp.Left(i), state); sl@0: test(returnValue>=0); sl@0: TBuf16 generatedsecondPartOfUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedsecondPartOfUnicode, aOriginalIso2022Jp.Mid(i-returnValue), state)==0); sl@0: generatedUnicode.Append(generatedsecondPartOfUnicode); sl@0: test(generatedUnicode==aExpectedUnicode); sl@0: } sl@0: } sl@0: /** sl@0: @SYMTestCaseID SYSLIB-CHARCONV-CT-0526 sl@0: @SYMTestCaseDesc Splitting and converting from ISO2022JP to Unicode test. sl@0: @SYMTestPriority Medium sl@0: @SYMTestActions Tests for conversion after splitting, from ISO2022JP to Unicode and back to ISO2022JP sl@0: @SYMTestExpectedResults Test must not fail sl@0: @SYMREQ REQ0000 sl@0: */ sl@0: void CT_ISO2022JP::TestSplittingConvertingToUnicodeFromIso2022Jp( sl@0: CCnvCharacterSetConverter& aCharacterSetConverter, sl@0: TInt aMaximumLengthLowerLimit, sl@0: TInt aMaximumLengthUpperLimit, sl@0: TInt aExpectedNumberOfIso2022JpBytesNotConvertedAtSplit, sl@0: TInt aExpectedLengthOfFirstPartOfUnicode, sl@0: const TDesC16& aExpectedUnicode, sl@0: const TDesC8& aOriginalIso2022Jp) sl@0: { sl@0: INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0526 ")); 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: const TInt returnValue=aCharacterSetConverter.ConvertToUnicode(generatedFirstPartOfUnicode, aOriginalIso2022Jp, state); sl@0: test(generatedFirstPartOfUnicode==aExpectedUnicode.Left(aExpectedLengthOfFirstPartOfUnicode)); sl@0: test(returnValue==aExpectedNumberOfIso2022JpBytesNotConvertedAtSplit); sl@0: TBuf16 generatedSecondPartOfUnicode; sl@0: test(aCharacterSetConverter.ConvertToUnicode(generatedSecondPartOfUnicode, aOriginalIso2022Jp.Right(aExpectedNumberOfIso2022JpBytesNotConvertedAtSplit), state)==0); sl@0: test(generatedSecondPartOfUnicode==aExpectedUnicode.Mid(aExpectedLengthOfFirstPartOfUnicode)); sl@0: TBuf8 generatedIso2022Jp; sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedIso2022Jp, generatedFirstPartOfUnicode)==0); sl@0: TBuf8 generatedSecondPartOfIso2022Jp; sl@0: test(aCharacterSetConverter.ConvertFromUnicode(generatedSecondPartOfIso2022Jp, generatedSecondPartOfUnicode)==0); sl@0: generatedIso2022Jp.Append(generatedSecondPartOfIso2022Jp); sl@0: TBuf16 regeneratedUnicode; sl@0: state=CCnvCharacterSetConverter::KStateDefault; sl@0: test(aCharacterSetConverter.ConvertToUnicode(regeneratedUnicode, generatedIso2022Jp, state)==0); sl@0: test(regeneratedUnicode==aExpectedUnicode); sl@0: state=CCnvCharacterSetConverter::KStateDefault; sl@0: test(aCharacterSetConverter.ConvertToUnicode(regeneratedUnicode, aOriginalIso2022Jp, state)==0); sl@0: test(regeneratedUnicode==aExpectedUnicode); sl@0: } sl@0: } sl@0: /** sl@0: @SYMTestCaseID SYSLIB-CHARCONV-CT-0527 sl@0: @SYMTestCaseDesc Conversion of bad ISO2022JP format to Unicode test sl@0: @SYMTestPriority Medium sl@0: @SYMTestActions Tests to convert bad format ISO2022JP input to Unicode. sl@0: @SYMTestExpectedResults Test must not fail sl@0: @SYMREQ REQ0000 sl@0: */ sl@0: void CT_ISO2022JP::TestIsIllFormedIso2022Jp(CCnvCharacterSetConverter& aCharacterSetConverter, const TDesC8& aIso2022Jp) sl@0: { sl@0: INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0527 ")); sl@0: TBuf16<50> generatedUnicode; sl@0: TInt state=CCnvCharacterSetConverter::KStateDefault; sl@0: TPtrC8 remainderOfIso2022Jp(aIso2022Jp); sl@0: TInt lastReturnValue=KMaxTInt; sl@0: FOREVER sl@0: { sl@0: const TInt returnValue=aCharacterSetConverter.ConvertToUnicode(generatedUnicode, remainderOfIso2022Jp, 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 ISO-2022-JP conversions")); sl@0: characterSetConverter->PrepareToConvertToOrFromL(KCharacterSetIdentifierIso2022Jp, *arrayOfCharacterSetsAvailable, fileServerSession); sl@0: // sl@0: INFO_PRINTF1(_L("Empty descriptor")); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 0, 10, 0, KNullDesC8, KNullDesC8, KNullDesC16); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 0, 10, 0, 0, KNullDesC16, KNullDesC8); sl@0: INFO_PRINTF1(_L("Testing converting to ISO-2022-JP")); sl@0: sl@0: _LIT(KTestUnicode,">.@>0l90"); sl@0: _LIT(KTestUnicode2,"\x0393\x03b1\x03c3\x03bf\x03c5\x3055\x3088"); sl@0: TestConversionFromUnicodeToIso(*characterSetConverter, KTestUnicode2); sl@0: TestConversionFromUnicodeToIso(*characterSetConverter, KTestUnicode); sl@0: sl@0: TBuf16<50> originalUnicode; sl@0: originalUnicode.Format(_L16("%c%c%c%c%c\xa5\\%c%c%c%c%c"), 0x0393, 0x03b1, 0x03c3, 0x03bf, 0x03c5, 0x3055, 0x3088, 0x3046, 0x306a, 0x3089); sl@0: TestTruncatedConversionFromUnicodeToIso2022Jp(*characterSetConverter, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 3, 7, 12, _L8(""), _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 8, 9, 11, _L8("\x1b\x24\x42\x26\x23\x1b\x28\x42"), _L8("\x1b\x24\x42\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 10, 11, 10, _L8("\x1b\x24\x42\x26\x23\x26\x41\x1b\x28\x42"), _L8("\x1b\x24\x42\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 12, 13, 9, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x1b\x28\x42"), _L8("\x1b\x24\x42\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 14, 15, 8, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x1b\x28\x42"), _L8("\x1b\x24\x42\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 16, 19, 7, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x42"), _L8("\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 20, 23, 6, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42"), _L8("\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 24, 28, 5, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\"), _L8("\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 29, 30, 4, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x1b\x28\x42"), _L8("\x1b\x24\x42\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 31, 32, 3, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x1b\x28\x42"), _L8("\x1b\x24\x42\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 33, 34, 2, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x1b\x28\x42"), _L8("\x1b\x24\x42\x24\x4a\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 35, 36, 1, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x1b\x28\x42"), _L8("\x1b\x24\x42\x24\x69\x1b\x28\x42"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 37, 50, 0, _L8("\x1b\x24\x42\x26\x23\x26\x41\x26\x52\x26\x4f\x26\x54\x1b\x28\x4a\\\x1b\x28\x42\\\x1b\x24\x42\x24\x35\x24\x68\x24\x26\x24\x4a\x24\x69\x1b\x28\x42"), KNullDesC8, originalUnicode); sl@0: originalUnicode.Format(_L16("%cX%cY%cZ"), 0x6153, 0x6376, 0x65d9); sl@0: TestTruncatedConversionFromUnicodeToIso2022Jp(*characterSetConverter, originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 3, 7, 6, _L8(""), _L8("\x1b\x24\x42XX\x1b\x28\x42X\x1b\x24\x42YY\x1b\x28\x42Y\x1b\x24\x42ZZ\x1b\x28\x42Z"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 8, 11, 5, _L8("\x1b\x24\x42XX\x1b\x28\x42"), _L8("X\x1b\x24\x42YY\x1b\x28\x42Y\x1b\x24\x42ZZ\x1b\x28\x42Z"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 12, 16, 4, _L8("\x1b\x24\x42XX\x1b\x28\x42X"), _L8("\x1b\x24\x42YY\x1b\x28\x42Y\x1b\x24\x42ZZ\x1b\x28\x42Z"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 17, 20, 3, _L8("\x1b\x24\x42XX\x1b\x28\x42X\x1b\x24\x42YY\x1b\x28\x42"), _L8("Y\x1b\x24\x42ZZ\x1b\x28\x42Z"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 21, 25, 2, _L8("\x1b\x24\x42XX\x1b\x28\x42X\x1b\x24\x42YY\x1b\x28\x42Y"), _L8("\x1b\x24\x42ZZ\x1b\x28\x42Z"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 26, 29, 1, _L8("\x1b\x24\x42XX\x1b\x28\x42X\x1b\x24\x42YY\x1b\x28\x42Y\x1b\x24\x42ZZ\x1b\x28\x42"), _L8("Z"), originalUnicode); sl@0: TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 30, 40, 0, _L8("\x1b\x24\x42XX\x1b\x28\x42X\x1b\x24\x42YY\x1b\x28\x42Y\x1b\x24\x42ZZ\x1b\x28\x42Z"), KNullDesC8, originalUnicode); sl@0: INFO_PRINTF1(_L("Testing converting to Unicode")); sl@0: const TPtrC8 originalIso2022Jp(_S8("\x1b\x24\x40\x1b\x28\x4aMy name is \x1b\x28\x4a\x1b\x28\x42\x1b\x24\x40\x25\x47\x25\x23\x25\x53\x25\x45\x1b\x28\x4a in \x1b\x24\x42\x46\x7c\x4b\x5c\x38\x6c\x1b\x28\x42\\~\x1b\x28\x4a\\~")); sl@0: TBuf16<50> expectedUnicode; sl@0: expectedUnicode.Format(_L16("My name is %c%c%c%c in %c%c%c\\~%c%c"), 0x30c7, 0x30a3, 0x30d3, 0x30c5, 0x65e5, 0x672c, 0x8a9e, 0x00a5, 0x203e); sl@0: TestTruncatedConversionToUnicodeFromIso2022Jp(*characterSetConverter, expectedUnicode, originalIso2022Jp); sl@0: TestTruncatedConversionToUnicodeFromIso2022Jp(*characterSetConverter, _L16(" Hello"), _L8("\x1b\x24\x42\x1b\x28\x4a\x1b\x24\x42\x1b\x28\x4a\x1b\x24\x42\x1b\x28\x4a Hello")); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 0, 0, 60, 0, expectedUnicode, originalIso2022Jp); sl@0: for (i=1; i<=10; ++i) sl@0: { sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, i, i, 54-i, i, expectedUnicode, originalIso2022Jp); sl@0: } sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 11, 11, 34, 11, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 12, 12, 32, 12, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 13, 13, 30, 13, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 14, 14, 28, 14, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 15, 15, 23, 15, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 16, 16, 22, 16, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 17, 17, 21, 17, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 18, 18, 20, 18, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 19, 19, 16, 19, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 20, 20, 14, 20, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 21, 21, 12, 21, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 22, 22, 7, 22, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 23, 23, 6, 23, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 24, 24, 2, 24, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 25, 25, 1, 25, expectedUnicode, originalIso2022Jp); sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 26, 40, 0, 26, expectedUnicode, originalIso2022Jp); sl@0: INFO_PRINTF1(_L("Testing the default ISO-2022-JP state")); sl@0: for (i=0; i<=6; ++i) sl@0: { sl@0: TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, i, i, 6-i, i, _L16("Hello\xa5"), _L8("Hello\\")); sl@0: } sl@0: INFO_PRINTF1(_L("Testing ill-formed ISO-2022-JP")); sl@0: TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24\x42\x21\x1b\x28\x4a def")); sl@0: TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24\x42\x21\x21\x21\x1b\x28\x4a def")); sl@0: TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24\x42\x21\x21\x21\x21\x21\x1b\x28\x4a def")); sl@0: TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b")); sl@0: TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24")); sl@0: TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24\xff")); sl@0: TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x26\x40")); sl@0: CleanupStack::PopAndDestroy(3); // arrayOfCharacterSetsAvailable and characterSetConverter and fileServerSession sl@0: } sl@0: sl@0: CT_ISO2022JP::CT_ISO2022JP() sl@0: { sl@0: SetTestStepName(KTestStep_T_ISO2022JP); sl@0: } sl@0: sl@0: TVerdict CT_ISO2022JP::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: } sl@0: