1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/os/textandloc/charconvfw/charconvplugins/test/rtest/tsrc/main/t_iso2022jp.cpp Fri Jun 15 03:10:57 2012 +0200
1.3 @@ -0,0 +1,356 @@
1.4 +/*
1.5 +* Copyright (c) 2000-2010 Nokia Corporation and/or its subsidiary(-ies).
1.6 +* All rights reserved.
1.7 +* This component and the accompanying materials are made available
1.8 +* under the terms of "Eclipse Public License v1.0"
1.9 +* which accompanies this distribution, and is available
1.10 +* at the URL "http://www.eclipse.org/legal/epl-v10.html".
1.11 +*
1.12 +* Initial Contributors:
1.13 +* Nokia Corporation - initial contribution.
1.14 +*
1.15 +* Contributors:
1.16 +*
1.17 +* Description:
1.18 +*
1.19 +*/
1.20 +
1.21 +
1.22 +#include <e32std.h>
1.23 +#include <e32base.h>
1.24 +#include <f32file.h>
1.25 +#include <charconv.h>
1.26 +#include "t_iso2022jp.h"
1.27 +
1.28 +#define test(cond) \
1.29 + { \
1.30 + TBool __bb = (cond); \
1.31 + TEST(__bb); \
1.32 + if (!__bb) \
1.33 + { \
1.34 + ERR_PRINTF1(_L("ERROR: Test Failed")); \
1.35 + User::Leave(1); \
1.36 + } \
1.37 + }
1.38 +
1.39 +const TInt KBufferLength=100;
1.40 +const TInt KNotEnoughBufferLength=17;
1.41 +/**
1.42 +@SYMTestCaseID SYSLIB-CHARCONV-CT-0522
1.43 +@SYMTestCaseDesc Tests for conversion from Unicode to ISO2022JP
1.44 +@SYMTestPriority Medium
1.45 +@SYMTestActions Tests for conversion from Unicode to ISO2022JP and back to Unicode
1.46 +@SYMTestExpectedResults Test must not fail
1.47 +@SYMREQ REQ0000
1.48 +*/
1.49 +void CT_ISO2022JP::TestConversionFromUnicodeToIso(
1.50 + CCnvCharacterSetConverter& aCharacterSetConverter,
1.51 + const TDesC16& aOriginalUnicode)
1.52 + {
1.53 + INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0522 "));
1.54 + TBuf8<KNotEnoughBufferLength> generatedIso2022Jp;
1.55 + generatedIso2022Jp.FillZ(KNotEnoughBufferLength);
1.56 + const TInt returnValue=aCharacterSetConverter.ConvertFromUnicode(generatedIso2022Jp, aOriginalUnicode);
1.57 + test(returnValue>=0);
1.58 + TInt state=CCnvCharacterSetConverter::KStateDefault;
1.59 + TBuf16<KBufferLength> generatedUnicode;
1.60 + TInt testresult;
1.61 + testresult=aCharacterSetConverter.ConvertToUnicode(generatedUnicode, generatedIso2022Jp, state);
1.62 + test(testresult==0);
1.63 + // test(generatedUnicode==aOriginalUnicode);
1.64 + }
1.65 +/**
1.66 +@SYMTestCaseID SYSLIB-CHARCONV-CT-0523
1.67 +@SYMTestCaseDesc Tests for truncated conversion from Unicode to ISO2022JP
1.68 +@SYMTestPriority Medium
1.69 +@SYMTestActions Tests for truncated conversion from Unicode to ISO2022JP and back to Unicode
1.70 +@SYMTestExpectedResults Test must not fail
1.71 +@SYMREQ REQ0000
1.72 +*/
1.73 +void CT_ISO2022JP::TestTruncatedConversionFromUnicodeToIso2022Jp(
1.74 + CCnvCharacterSetConverter& aCharacterSetConverter,
1.75 + const TDesC16& aOriginalUnicode)
1.76 + {
1.77 + INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0523 "));
1.78 + for (TInt i=aOriginalUnicode.Length(); i>=0; --i)
1.79 + {
1.80 + TBuf8<KBufferLength> generatedIso2022Jp;
1.81 + const TInt returnValue=aCharacterSetConverter.ConvertFromUnicode(generatedIso2022Jp, aOriginalUnicode.Left(i));
1.82 + test(returnValue>=0);
1.83 + TBuf8<KBufferLength> generatedsecondPartOfIso2022Jp;
1.84 + test(aCharacterSetConverter.ConvertFromUnicode(generatedsecondPartOfIso2022Jp, aOriginalUnicode.Mid(i-returnValue))==0);
1.85 + generatedIso2022Jp.Append(generatedsecondPartOfIso2022Jp);
1.86 + TInt state=CCnvCharacterSetConverter::KStateDefault;
1.87 + TBuf16<KBufferLength> generatedUnicode;
1.88 + test(aCharacterSetConverter.ConvertToUnicode(generatedUnicode, generatedIso2022Jp, state)==0);
1.89 + test(generatedUnicode==aOriginalUnicode);
1.90 + }
1.91 + }
1.92 +/**
1.93 +@SYMTestCaseID SYSLIB-CHARCONV-CT-0524
1.94 +@SYMTestCaseDesc Splitting and converting from Unicode to ISO2022JP test
1.95 +@SYMTestPriority Medium
1.96 +@SYMTestActions Tests for conversion after splitting, from Unicode to ISO2022JP and back to Unicode
1.97 +@SYMTestExpectedResults Test must not fail
1.98 +@SYMREQ REQ0000
1.99 +*/
1.100 +void CT_ISO2022JP::TestSplittingConvertingFromUnicodeToIso2022Jp(
1.101 + CCnvCharacterSetConverter& aCharacterSetConverter,
1.102 + TInt aMaximumLengthLowerLimit,
1.103 + TInt aMaximumLengthUpperLimit,
1.104 + TInt aExpectedNumberOfUnicodeCharactersNotConvertedAtSplit,
1.105 + const TDesC8& aExpectedFirstPartOfIso2022Jp,
1.106 + const TDesC8& aExpectedSecondPartOfIso2022Jp,
1.107 + const TDesC16& aOriginalUnicode)
1.108 + {
1.109 + INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0524 "));
1.110 + test(aMaximumLengthLowerLimit<=aMaximumLengthUpperLimit);
1.111 + test(aMaximumLengthUpperLimit<=KBufferLength);
1.112 + TUint8 iso2022JpBuffer[KBufferLength];
1.113 + for (TInt i=aMaximumLengthLowerLimit; i<=aMaximumLengthUpperLimit; ++i)
1.114 + {
1.115 + TPtr8 generatedFirstPartOfIso2022Jp(iso2022JpBuffer, i);
1.116 + test(aCharacterSetConverter.ConvertFromUnicode(generatedFirstPartOfIso2022Jp, aOriginalUnicode)==aExpectedNumberOfUnicodeCharactersNotConvertedAtSplit);
1.117 + test(generatedFirstPartOfIso2022Jp==aExpectedFirstPartOfIso2022Jp);
1.118 + TBuf8<KBufferLength> generatedSecondPartOfIso2022Jp;
1.119 + test(aCharacterSetConverter.ConvertFromUnicode(generatedSecondPartOfIso2022Jp, aOriginalUnicode.Right(aExpectedNumberOfUnicodeCharactersNotConvertedAtSplit))==0);
1.120 + test(generatedSecondPartOfIso2022Jp==aExpectedSecondPartOfIso2022Jp);
1.121 + TInt state=CCnvCharacterSetConverter::KStateDefault;
1.122 + TBuf16<KBufferLength> generatedUnicode;
1.123 + test(aCharacterSetConverter.ConvertToUnicode(generatedUnicode, generatedFirstPartOfIso2022Jp, state)==0);
1.124 + TBuf16<KBufferLength> generatedSecondPartOfUnicode;
1.125 + test(aCharacterSetConverter.ConvertToUnicode(generatedSecondPartOfUnicode, generatedSecondPartOfIso2022Jp, state)==0);
1.126 + generatedUnicode.Append(generatedSecondPartOfUnicode);
1.127 + test(generatedUnicode==aOriginalUnicode);
1.128 + }
1.129 + }
1.130 +/**
1.131 +@SYMTestCaseID SYSLIB-CHARCONV-CT-0525
1.132 +@SYMTestCaseDesc Tests for truncated conversion from ISO2022JP to Unicode test
1.133 +@SYMTestPriority Medium
1.134 +@SYMTestActions Tests for truncated conversion from ISO2022JP to Unicode and back to ISO2022JP
1.135 +@SYMTestExpectedResults Test must not fail
1.136 +@SYMREQ REQ0000
1.137 +*/
1.138 +void CT_ISO2022JP::TestTruncatedConversionToUnicodeFromIso2022Jp(
1.139 + CCnvCharacterSetConverter& aCharacterSetConverter,
1.140 + const TDesC16& aExpectedUnicode,
1.141 + const TDesC8& aOriginalIso2022Jp)
1.142 + {
1.143 + INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0525 "));
1.144 + for (TInt i=aOriginalIso2022Jp.Length(); i>=3; --i) // 3 is the length of ISO-2022-JP's longest escape sequence
1.145 + {
1.146 + TInt state=CCnvCharacterSetConverter::KStateDefault;
1.147 + TBuf16<KBufferLength> generatedUnicode;
1.148 + const TInt returnValue=aCharacterSetConverter.ConvertToUnicode(generatedUnicode, aOriginalIso2022Jp.Left(i), state);
1.149 + test(returnValue>=0);
1.150 + TBuf16<KBufferLength> generatedsecondPartOfUnicode;
1.151 + test(aCharacterSetConverter.ConvertToUnicode(generatedsecondPartOfUnicode, aOriginalIso2022Jp.Mid(i-returnValue), state)==0);
1.152 + generatedUnicode.Append(generatedsecondPartOfUnicode);
1.153 + test(generatedUnicode==aExpectedUnicode);
1.154 + }
1.155 + }
1.156 +/**
1.157 +@SYMTestCaseID SYSLIB-CHARCONV-CT-0526
1.158 +@SYMTestCaseDesc Splitting and converting from ISO2022JP to Unicode test.
1.159 +@SYMTestPriority Medium
1.160 +@SYMTestActions Tests for conversion after splitting, from ISO2022JP to Unicode and back to ISO2022JP
1.161 +@SYMTestExpectedResults Test must not fail
1.162 +@SYMREQ REQ0000
1.163 +*/
1.164 +void CT_ISO2022JP::TestSplittingConvertingToUnicodeFromIso2022Jp(
1.165 + CCnvCharacterSetConverter& aCharacterSetConverter,
1.166 + TInt aMaximumLengthLowerLimit,
1.167 + TInt aMaximumLengthUpperLimit,
1.168 + TInt aExpectedNumberOfIso2022JpBytesNotConvertedAtSplit,
1.169 + TInt aExpectedLengthOfFirstPartOfUnicode,
1.170 + const TDesC16& aExpectedUnicode,
1.171 + const TDesC8& aOriginalIso2022Jp)
1.172 + {
1.173 + INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0526 "));
1.174 + test(aMaximumLengthLowerLimit<=aMaximumLengthUpperLimit);
1.175 + test(aMaximumLengthUpperLimit<=KBufferLength);
1.176 + TUint16 unicodeBuffer[KBufferLength];
1.177 + for (TInt i=aMaximumLengthLowerLimit; i<=aMaximumLengthUpperLimit; ++i)
1.178 + {
1.179 + TPtr16 generatedFirstPartOfUnicode(unicodeBuffer, i);
1.180 + TInt state=CCnvCharacterSetConverter::KStateDefault;
1.181 + const TInt returnValue=aCharacterSetConverter.ConvertToUnicode(generatedFirstPartOfUnicode, aOriginalIso2022Jp, state);
1.182 + test(generatedFirstPartOfUnicode==aExpectedUnicode.Left(aExpectedLengthOfFirstPartOfUnicode));
1.183 + test(returnValue==aExpectedNumberOfIso2022JpBytesNotConvertedAtSplit);
1.184 + TBuf16<KBufferLength> generatedSecondPartOfUnicode;
1.185 + test(aCharacterSetConverter.ConvertToUnicode(generatedSecondPartOfUnicode, aOriginalIso2022Jp.Right(aExpectedNumberOfIso2022JpBytesNotConvertedAtSplit), state)==0);
1.186 + test(generatedSecondPartOfUnicode==aExpectedUnicode.Mid(aExpectedLengthOfFirstPartOfUnicode));
1.187 + TBuf8<KBufferLength> generatedIso2022Jp;
1.188 + test(aCharacterSetConverter.ConvertFromUnicode(generatedIso2022Jp, generatedFirstPartOfUnicode)==0);
1.189 + TBuf8<KBufferLength> generatedSecondPartOfIso2022Jp;
1.190 + test(aCharacterSetConverter.ConvertFromUnicode(generatedSecondPartOfIso2022Jp, generatedSecondPartOfUnicode)==0);
1.191 + generatedIso2022Jp.Append(generatedSecondPartOfIso2022Jp);
1.192 + TBuf16<KBufferLength> regeneratedUnicode;
1.193 + state=CCnvCharacterSetConverter::KStateDefault;
1.194 + test(aCharacterSetConverter.ConvertToUnicode(regeneratedUnicode, generatedIso2022Jp, state)==0);
1.195 + test(regeneratedUnicode==aExpectedUnicode);
1.196 + state=CCnvCharacterSetConverter::KStateDefault;
1.197 + test(aCharacterSetConverter.ConvertToUnicode(regeneratedUnicode, aOriginalIso2022Jp, state)==0);
1.198 + test(regeneratedUnicode==aExpectedUnicode);
1.199 + }
1.200 + }
1.201 +/**
1.202 +@SYMTestCaseID SYSLIB-CHARCONV-CT-0527
1.203 +@SYMTestCaseDesc Conversion of bad ISO2022JP format to Unicode test
1.204 +@SYMTestPriority Medium
1.205 +@SYMTestActions Tests to convert bad format ISO2022JP input to Unicode.
1.206 +@SYMTestExpectedResults Test must not fail
1.207 +@SYMREQ REQ0000
1.208 +*/
1.209 +void CT_ISO2022JP::TestIsIllFormedIso2022Jp(CCnvCharacterSetConverter& aCharacterSetConverter, const TDesC8& aIso2022Jp)
1.210 + {
1.211 + INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0527 "));
1.212 + TBuf16<50> generatedUnicode;
1.213 + TInt state=CCnvCharacterSetConverter::KStateDefault;
1.214 + TPtrC8 remainderOfIso2022Jp(aIso2022Jp);
1.215 + TInt lastReturnValue=KMaxTInt;
1.216 + FOREVER
1.217 + {
1.218 + const TInt returnValue=aCharacterSetConverter.ConvertToUnicode(generatedUnicode, remainderOfIso2022Jp, state);
1.219 + if (returnValue==CCnvCharacterSetConverter::EErrorIllFormedInput)
1.220 + {
1.221 + break;
1.222 + }
1.223 + test(returnValue>0);
1.224 + test(returnValue<lastReturnValue);
1.225 + lastReturnValue=returnValue;
1.226 + remainderOfIso2022Jp.Set(remainderOfIso2022Jp.Right(returnValue));
1.227 + }
1.228 + }
1.229 +/**
1.230 +@SYMTestCaseID SYSLIB-CHARCONV-CT-0528
1.231 +@SYMTestCaseDesc ISO2022JP to Unicode and Unicode to ISO2022JP conversion tests
1.232 +@SYMTestPriority Medium
1.233 +@SYMTestActions Call up conversion of ISO2022JP to Unicode test functions
1.234 +@SYMTestExpectedResults Test must not fail
1.235 +@SYMREQ REQ0000
1.236 +*/
1.237 +void CT_ISO2022JP::DoE32MainL()
1.238 + {
1.239 + INFO_PRINTF1(_L(" @SYMTestCaseID:SYSLIB-CHARCONV-CT-0528 "));
1.240 + RFs fileServerSession;
1.241 + CleanupClosePushL(fileServerSession);
1.242 + User::LeaveIfError(fileServerSession.Connect());
1.243 + CCnvCharacterSetConverter* characterSetConverter=CCnvCharacterSetConverter::NewLC();
1.244 + CArrayFix<CCnvCharacterSetConverter::SCharacterSet>* arrayOfCharacterSetsAvailable=CCnvCharacterSetConverter::CreateArrayOfCharacterSetsAvailableLC(fileServerSession);
1.245 + INFO_PRINTF1(_L("Available:\n"));
1.246 + TInt i;
1.247 + for (i=arrayOfCharacterSetsAvailable->Count()-1; i>=0; --i)
1.248 + {
1.249 + const CCnvCharacterSetConverter::SCharacterSet& charactersSet=(*arrayOfCharacterSetsAvailable)[i];
1.250 + characterSetConverter->PrepareToConvertToOrFromL(charactersSet.Identifier(), *arrayOfCharacterSetsAvailable, fileServerSession);
1.251 + TPtrC charactersSetName(charactersSet.Name());
1.252 + if (charactersSet.NameIsFileName())
1.253 + {
1.254 + charactersSetName.Set(TParsePtrC(charactersSetName).Name());
1.255 + }
1.256 + INFO_PRINTF2(_L(" %S\n"), &charactersSetName);
1.257 + }
1.258 + INFO_PRINTF1(_L("Testing ISO-2022-JP conversions"));
1.259 + characterSetConverter->PrepareToConvertToOrFromL(KCharacterSetIdentifierIso2022Jp, *arrayOfCharacterSetsAvailable, fileServerSession);
1.260 + //
1.261 + INFO_PRINTF1(_L("Empty descriptor"));
1.262 + TestSplittingConvertingFromUnicodeToIso2022Jp(*characterSetConverter, 0, 10, 0, KNullDesC8, KNullDesC8, KNullDesC16);
1.263 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 0, 10, 0, 0, KNullDesC16, KNullDesC8);
1.264 + INFO_PRINTF1(_L("Testing converting to ISO-2022-JP"));
1.265 +
1.266 + _LIT(KTestUnicode,">.@>0l90");
1.267 + _LIT(KTestUnicode2,"\x0393\x03b1\x03c3\x03bf\x03c5\x3055\x3088");
1.268 + TestConversionFromUnicodeToIso(*characterSetConverter, KTestUnicode2);
1.269 + TestConversionFromUnicodeToIso(*characterSetConverter, KTestUnicode);
1.270 +
1.271 + TBuf16<50> originalUnicode;
1.272 + originalUnicode.Format(_L16("%c%c%c%c%c\xa5\\%c%c%c%c%c"), 0x0393, 0x03b1, 0x03c3, 0x03bf, 0x03c5, 0x3055, 0x3088, 0x3046, 0x306a, 0x3089);
1.273 + TestTruncatedConversionFromUnicodeToIso2022Jp(*characterSetConverter, originalUnicode);
1.274 + 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);
1.275 + 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);
1.276 + 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);
1.277 + 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);
1.278 + 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);
1.279 + 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);
1.280 + 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);
1.281 + 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);
1.282 + 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);
1.283 + 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);
1.284 + 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);
1.285 + 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);
1.286 + 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);
1.287 + originalUnicode.Format(_L16("%cX%cY%cZ"), 0x6153, 0x6376, 0x65d9);
1.288 + TestTruncatedConversionFromUnicodeToIso2022Jp(*characterSetConverter, originalUnicode);
1.289 + 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);
1.290 + 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);
1.291 + 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);
1.292 + 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);
1.293 + 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);
1.294 + 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);
1.295 + 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);
1.296 + INFO_PRINTF1(_L("Testing converting to Unicode"));
1.297 + 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\\~"));
1.298 + TBuf16<50> expectedUnicode;
1.299 + 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);
1.300 + TestTruncatedConversionToUnicodeFromIso2022Jp(*characterSetConverter, expectedUnicode, originalIso2022Jp);
1.301 + TestTruncatedConversionToUnicodeFromIso2022Jp(*characterSetConverter, _L16(" Hello"), _L8("\x1b\x24\x42\x1b\x28\x4a\x1b\x24\x42\x1b\x28\x4a\x1b\x24\x42\x1b\x28\x4a Hello"));
1.302 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 0, 0, 60, 0, expectedUnicode, originalIso2022Jp);
1.303 + for (i=1; i<=10; ++i)
1.304 + {
1.305 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, i, i, 54-i, i, expectedUnicode, originalIso2022Jp);
1.306 + }
1.307 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 11, 11, 34, 11, expectedUnicode, originalIso2022Jp);
1.308 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 12, 12, 32, 12, expectedUnicode, originalIso2022Jp);
1.309 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 13, 13, 30, 13, expectedUnicode, originalIso2022Jp);
1.310 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 14, 14, 28, 14, expectedUnicode, originalIso2022Jp);
1.311 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 15, 15, 23, 15, expectedUnicode, originalIso2022Jp);
1.312 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 16, 16, 22, 16, expectedUnicode, originalIso2022Jp);
1.313 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 17, 17, 21, 17, expectedUnicode, originalIso2022Jp);
1.314 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 18, 18, 20, 18, expectedUnicode, originalIso2022Jp);
1.315 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 19, 19, 16, 19, expectedUnicode, originalIso2022Jp);
1.316 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 20, 20, 14, 20, expectedUnicode, originalIso2022Jp);
1.317 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 21, 21, 12, 21, expectedUnicode, originalIso2022Jp);
1.318 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 22, 22, 7, 22, expectedUnicode, originalIso2022Jp);
1.319 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 23, 23, 6, 23, expectedUnicode, originalIso2022Jp);
1.320 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 24, 24, 2, 24, expectedUnicode, originalIso2022Jp);
1.321 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 25, 25, 1, 25, expectedUnicode, originalIso2022Jp);
1.322 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, 26, 40, 0, 26, expectedUnicode, originalIso2022Jp);
1.323 + INFO_PRINTF1(_L("Testing the default ISO-2022-JP state"));
1.324 + for (i=0; i<=6; ++i)
1.325 + {
1.326 + TestSplittingConvertingToUnicodeFromIso2022Jp(*characterSetConverter, i, i, 6-i, i, _L16("Hello\xa5"), _L8("Hello\\"));
1.327 + }
1.328 + INFO_PRINTF1(_L("Testing ill-formed ISO-2022-JP"));
1.329 + TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24\x42\x21\x1b\x28\x4a def"));
1.330 + TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24\x42\x21\x21\x21\x1b\x28\x4a def"));
1.331 + TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24\x42\x21\x21\x21\x21\x21\x1b\x28\x4a def"));
1.332 + TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b"));
1.333 + TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24"));
1.334 + TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x24\xff"));
1.335 + TestIsIllFormedIso2022Jp(*characterSetConverter, _L8("abc \x1b\x26\x40"));
1.336 + CleanupStack::PopAndDestroy(3); // arrayOfCharacterSetsAvailable and characterSetConverter and fileServerSession
1.337 + }
1.338 +
1.339 +CT_ISO2022JP::CT_ISO2022JP()
1.340 + {
1.341 + SetTestStepName(KTestStep_T_ISO2022JP);
1.342 + }
1.343 +
1.344 +TVerdict CT_ISO2022JP::doTestStepL()
1.345 + {
1.346 + SetTestStepResult(EFail);
1.347 +
1.348 + __UHEAP_MARK;
1.349 + TRAPD(error1, DoE32MainL());
1.350 + __UHEAP_MARKEND;
1.351 +
1.352 + if(error1 == KErrNone)
1.353 + {
1.354 + SetTestStepResult(EPass);
1.355 + }
1.356 +
1.357 + return TestStepResult();
1.358 + }
1.359 +