gecko-dev/intl/uconv/tests/nsTestUConv.cpp

1133 lines
30 KiB
C++
Raw Normal View History

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
*
* The contents of this file are subject to the Netscape Public License
* Version 1.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
* http://www.mozilla.org/NPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and limitations
* under the License.
*
* The Original Code is Mozilla Communicator client code.
*
* The Initial Developer of the Original Code is Netscape Communications
* Corporation. Portions created by Netscape are Copyright (C) 1998
* Netscape Communications Corporation. All Rights Reserved.
*/
#define NS_IMPL_IDS
#include <stdio.h>
1999-02-18 00:55:19 +00:00
#include <string.h>
#include "nsIComponentManager.h"
1999-02-18 00:55:19 +00:00
#include "nsIServiceManager.h"
#include "nsISupports.h"
#include "nsICharsetConverterManager.h"
#include "nsIPlatformCharset.h"
1999-02-12 19:50:47 +00:00
// include the CIDs
1999-01-14 23:23:30 +00:00
#include "nsUCvLatinCID.h"
1999-02-12 19:50:47 +00:00
#include "nsUCVJACID.h"
#include "nsUCVJA2CID.h"
1999-01-12 08:35:45 +00:00
#ifdef XP_UNIX
#define UCONV_DLL "libuconv.so"
#define UCVLATIN_DLL "libucvlatin.so"
#define UCVJA_DLL "libucvja.so"
1999-02-12 19:50:47 +00:00
#define UCVJA2_DLL "libucvja2.so"
#else /* XP_UNIX */
#ifdef XP_MAC
#define UCONV_DLL "UCONV_DLL"
#define UCVLATIN_DLL "UCVLATIN_DLL"
#define UCVJA_DLL "UCVJA_DLL"
1999-02-12 19:50:47 +00:00
#define UCVJA2_DLL "UCVJA2_DLL"
#else /* XP_MAC */
#define UCONV_DLL "uconv.dll"
#define UCVLATIN_DLL "ucvlatin.dll"
#define UCVJA_DLL "ucvja.dll"
1999-02-12 19:50:47 +00:00
#define UCVJA2_DLL "ucvja2.dll"
#endif
#endif
1999-02-12 19:50:47 +00:00
/**
* Test program for the Unicode Converters.
*
* Error messages format inside of a test.
*
* - silent while all is OK.
*
1999-02-18 00:55:19 +00:00
* - "ERROR at T001.easyConversion.Convert() code=0xfffd.\n"
* - "ERROR at T001.easyConversion.ConvResLen expected=0x02 result=0x04.\n"
1999-02-12 19:50:47 +00:00
*
* - "Test Passed.\n" for a successful end.
*
* @created 01/Dec/1998
* @author Catalin Rotaru [CATA]
*/
//----------------------------------------------------------------------
// Global variables and macros
1999-01-12 08:35:45 +00:00
1999-02-18 00:55:19 +00:00
#define GENERAL_BUFFER 20000 // general purpose buffer; for Unicode divide by 2
nsICharsetConverterManager * ccMan = NULL;
1999-02-12 19:50:47 +00:00
//----------------------------------------------------------------------
// Registry setup function(s)
nsresult setupRegistry()
{
nsresult res;
res = nsComponentManager::RegisterComponent(kCharsetConverterManagerCID, NULL, NULL, UCONV_DLL, PR_FALSE, PR_FALSE);
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
res = nsComponentManager::RegisterComponent(kLatin1ToUnicodeCID, NULL, NULL, UCVLATIN_DLL, PR_FALSE, PR_FALSE);
1999-01-12 08:35:45 +00:00
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
res = nsComponentManager::RegisterComponent(kCP1253ToUnicodeCID, NULL, NULL, UCVLATIN_DLL, PR_FALSE, PR_FALSE);
1999-01-14 23:23:30 +00:00
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
res = nsComponentManager::RegisterComponent(kISO88597ToUnicodeCID, NULL, NULL, UCVLATIN_DLL, PR_FALSE, PR_FALSE);
1999-01-14 23:23:30 +00:00
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
res = nsComponentManager::RegisterComponent(kSJIS2UnicodeCID, NULL, NULL, UCVJA_DLL, PR_FALSE, PR_FALSE);
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
1999-01-12 08:35:45 +00:00
res = nsComponentManager::RegisterComponent(kISO2022JPToUnicodeCID, NULL, NULL, UCVJA2_DLL, PR_FALSE, PR_FALSE);
1999-02-12 19:50:47 +00:00
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
res = nsComponentManager::RegisterComponent(kPlatformCharsetCID, NULL, NULL, UCONV_DLL, PR_FALSE, PR_FALSE);
if (NS_FAILED(res) && (NS_ERROR_FACTORY_EXISTS != res)) return res;
return NS_OK;
}
1999-02-12 19:50:47 +00:00
//----------------------------------------------------------------------
// Converter Manager test code
nsresult testCharsetConverterManager()
{
1999-02-18 00:55:19 +00:00
printf("\n[T001] CharsetConverterManager\n");
1999-02-18 00:55:19 +00:00
nsresult res = nsServiceManager::GetService(kCharsetConverterManagerCID,
kICharsetConverterManagerIID, (nsISupports **)&ccMan);
if (NS_FAILED(res)) {
1999-02-18 00:55:19 +00:00
printf("ERROR at GetService() code=0x%x.\n",res);
return res;
}
nsString ** cs;
PRInt32 ct;
1999-02-18 00:55:19 +00:00
res = ccMan->GetDecodableCharsets(&cs, &ct);
if (NS_FAILED(res)) {
1999-02-18 00:55:19 +00:00
printf("ERROR at GetDecodableCharsets() code=0x%x.\n", res);
} else {
1999-02-18 00:55:19 +00:00
printf("UDecoders (%d): ", ct);
for (int i=0;i<ct;i++) {
char * cstr = cs[i]->ToNewCString();
printf("%s ",cstr);
delete [] cstr;
}
printf("\n");
}
delete [] cs;
1999-02-18 00:55:19 +00:00
res = ccMan->GetEncodableCharsets(&cs, &ct);
if (NS_FAILED(res)) {
1999-02-18 00:55:19 +00:00
printf("ERROR at GetEncodableCharsets() code=0x%x.\n", res);
} else {
1999-02-18 00:55:19 +00:00
printf("UEncoders (%d): ", ct);
for (int i=0;i<ct;i++) {
char * cstr = cs[i]->ToNewCString();
printf("%s ",cstr);
delete [] cstr;
}
printf("\n");
}
delete [] cs;
return NS_OK;
}
1999-02-12 19:50:47 +00:00
//----------------------------------------------------------------------
// Old SHIT !!! Don't copy this crap, go to the new stuff down in the file.
1999-02-18 00:55:19 +00:00
// XXX move it to the new & improved framework
1999-01-14 23:23:30 +00:00
1999-02-12 19:50:47 +00:00
#define TABLE_SIZE1 5
1999-01-14 23:23:30 +00:00
#define ISO88597TABLE_SIZE 16
nsresult testISO88597Decoder()
{
printf("\n[T3] ISO-8859-7 To Unicode\n");
// create converter
nsIUnicodeDecoder * dec;
nsAutoString str("iso-8859-7");
nsresult res = ccMan->GetUnicodeDecoder(&str,&dec);
if (NS_FAILED(res)) {
printf("ERROR 0x%x: Cannot instantiate.\n",res);
return res;
} else {
printf("Instantiated.\n");
}
//test converter
PRInt32 srcL = ISO88597TABLE_SIZE;
PRInt32 destL = ISO88597TABLE_SIZE;
// some randon C0, ASCII, C1 and ISO-8859-7 code
static char src [ISO88597TABLE_SIZE + 1] =
{
"\x09\x0d\x20\x40"
"\x80\x98\xa3\xaf"
"\xa7\xb1\xb3\xc9"
"\xd9\xe3\xf4\xff"
};
static PRUnichar expect [ISO88597TABLE_SIZE] =
{
0x0009, 0x000d, 0x0020, 0x0040,
0xfffd, 0xfffd, 0x00a3, 0x2015,
0x00a7, 0x00b1, 0x00b3, 0x0399,
0x03a9, 0x03b3, 0x03c4, 0xfffd
};
PRUnichar dest [ISO88597TABLE_SIZE];
res=dec->Convert(dest, 0, &destL, src, 0, &srcL);
if (NS_FAILED(res)) {
printf("ERROR 0x%x: Convert().\n",res);
} else {
printf("Read %d, write %d.\n",srcL,destL);
printf("Converted:");
PRBool failed = PR_FALSE;
for (int i=0;i<ISO88597TABLE_SIZE;i++) {
printf("%x convert to %x. expect value is %x\n" , src[i], dest[i], expect[i]);
if (dest[i] != expect[i]) failed = PR_TRUE;
}
printf("\n");
if (failed) {
printf("Test FAILED!!!\n");
} else {
printf("Test Passed.\n");
}
}
NS_RELEASE(dec);
return NS_OK;
}
1999-01-12 08:35:45 +00:00
#define SJIS_TEST_SRC_SIZE 40
#define SJIS_TEST_DEST_SIZE 24
nsresult testSJISDecoder()
{
/*
[Shift_JIS=4a][Shift_JIS=61][Shift_JIS=70][Shift_JIS=61][Shift_JIS=6e][Shift_JIS=65][Shift_JIS=73][Shift_JIS=65]
[Shift_JIS=8abf][Shift_JIS=8e9a]
[Shift_JIS=834a][Shift_JIS=835e][Shift_JIS=834a][Shift_JIS=8369]
[Shift_JIS=82d0][Shift_JIS=82e7][Shift_JIS=82aa][Shift_JIS=82c8]
[Shift_JIS=8250][Shift_JIS=8251][Shift_JIS=8252][Shift_JIS=8260][Shift_JIS=8261][Shift_JIS=8262]
U+004A U+0061 U+0070 U+0061 U+006E U+0065 U+0073 U+0065
U+6F22 U+5B57
U+30AB U+30BF U+30AB U+30CA
U+3072 U+3089 U+304C U+306A
U+FF11 U+FF12 U+FF13 U+FF21 U+FF22 U+FF23
*/
static const char src[SJIS_TEST_SRC_SIZE + 1] = {
"Japanese" /* English */
"\x8a\xbf\x8e\x9a" /* Kanji */
"\x83\x4a\x83\x5e\x83\x4a\x83\x69" /* Kantakana */
"\x82\xd0\x82\xe7\x82\xaa\x82\xc8" /* Hiragana */
"\x82\x50\x82\x51\x82\x52\x82\x60\x82\x61\x82\x62" /* full width 123ABC */
};
static const PRUnichar expect[SJIS_TEST_DEST_SIZE] = {
0x004A, 0x0061, 0x0070, 0x0061, 0x006E, 0x0065, 0x0073, 0x0065,
0x6f22, 0x5b57,
0x30ab, 0x30bf, 0x30ab, 0x30ca,
0x3072, 0x3089, 0x304c, 0x306a,
0xff11, 0xff12, 0xff13, 0xff21, 0xff22, 0xff23
};
PRUnichar dest[SJIS_TEST_DEST_SIZE + 44];
printf("\n[T3] SJIS2Unicode\n");
// create converter
nsIUnicodeDecoder * dec;
nsAutoString str("Shift_JIS");
nsresult res = ccMan->GetUnicodeDecoder(&str,&dec);
if (NS_FAILED(res)) {
printf("ERROR 0x%x: Cannot instantiate.\n",res);
return res;
} else {
printf("Instantiated.\n");
}
//test converter
PRInt32 srcL = SJIS_TEST_SRC_SIZE;
PRInt32 destL = SJIS_TEST_DEST_SIZE+ 44;
PRBool failed = PR_FALSE;
printf("Test Normal Case\n");
res=dec->Convert(dest, 0, &destL, src, 0, &srcL);
if (NS_FAILED(res)) {
printf("ERROR 0x%x: Convert().\n",res);
failed = PR_TRUE;
} else {
printf("Read %d, write %d.\n",srcL,destL);
printf("Converted:");
1999-01-12 08:35:45 +00:00
if(destL != SJIS_TEST_DEST_SIZE)
{
printf("Dest Size bad. Should be %d but got %d!!\n",
SJIS_TEST_DEST_SIZE, destL);
failed = PR_TRUE;
}
for (int i=0;i< destL ;i++) {
if (dest[i] != expect[i] ) failed = PR_TRUE;
}
printf("\n");
if (failed) {
printf("Test FAILED!!!\n");
} else {
printf("Test Passed.\n");
}
failed = PR_FALSE;
// Test NS_PARTIAL_MORE_INPUT case
printf("Test NS_PARTIAL_MORE_INPUT Case\n");
srcL= SJIS_TEST_SRC_SIZE - 1;
destL = SJIS_TEST_DEST_SIZE+ 44;
res=dec->Convert(dest, 0, &destL, src, 0, &srcL);
if (NS_PARTIAL_MORE_INPUT != res) {
printf("ERROR 0x%x: Convert().\n",res);
failed = PR_TRUE;
} else {
if((SJIS_TEST_SRC_SIZE -2 ) != srcL )
{
printf("Src Size bad. Should be %d but got %d!!\n",
SJIS_TEST_SRC_SIZE-2, srcL);
failed = PR_TRUE;
}
if(destL != (SJIS_TEST_DEST_SIZE-1))
{
printf("Dest Size bad. Should be %d but got %d!!\n",
SJIS_TEST_DEST_SIZE-1, destL);
failed = PR_TRUE;
}
for (int i=0;i< destL ;i++) {
if (dest[i] != expect[i] ) failed = PR_TRUE;
}
}
if (failed) {
printf("Test FAILED!!!\n");
} else {
printf("Test Passed.\n");
}
failed = PR_FALSE;
// Test NS_PARTIAL_MORE_OUTPUT case
printf("Test NS_PARTIAL_MORE_OUTNPUT Case\n");
srcL= SJIS_TEST_SRC_SIZE;
destL = SJIS_TEST_DEST_SIZE-1;
res=dec->Convert(dest, 0, &destL, src, 0, &srcL);
if (NS_PARTIAL_MORE_OUTPUT != res) {
printf("ERROR 0x%x: Convert().\n",res);
failed = PR_TRUE;
} else {
if((SJIS_TEST_SRC_SIZE -2 ) != srcL )
{
printf("Src Size bad. Should be %d but got %d!!\n",
SJIS_TEST_SRC_SIZE-2, srcL);
failed = PR_TRUE;
}
if(destL != (SJIS_TEST_DEST_SIZE-1))
{
printf("Dest Size bad. Should be %d but got %d!!\n",
SJIS_TEST_DEST_SIZE-1, destL);
failed = PR_TRUE;
}
for (int i=0;i< destL ;i++) {
if (dest[i] != expect[i] ) failed = PR_TRUE;
}
}
// Test NS_ERROR_ILLEGAL_INPUT case
//printf("Test NS_ERROR_ILLEGAL_INPUT Case\n");
// To Be Implement
if (failed) {
printf("Test FAILED!!!\n");
} else {
printf("Test Passed.\n");
}
}
NS_RELEASE(dec);
return NS_OK;
}
1999-02-12 19:50:47 +00:00
//----------------------------------------------------------------------
// Helper functions and macros for testing decoders and encoders
1999-02-18 00:55:19 +00:00
#define CREATE_DECODER(_charset) \
nsIUnicodeDecoder * dec; \
nsAutoString str(_charset); \
nsresult res = ccMan->GetUnicodeDecoder(&str,&dec); \
if (NS_FAILED(res)) { \
printf("ERROR at GetUnicodeDecoder() code=0x%x.\n",res); \
return res; \
1999-02-12 19:50:47 +00:00
}
1999-02-18 00:55:19 +00:00
#define CREATE_ENCODER(_charset) \
nsIUnicodeEncoder * enc; \
nsAutoString str(_charset); \
nsresult res = ccMan->GetUnicodeEncoder(&str,&enc); \
if (NS_FAILED(res)) { \
printf("ERROR at GetUnicodeEncoder() code=0x%x.\n",res); \
return res; \
}
#define ARRAY_SIZE(_array) \
1999-02-12 19:50:47 +00:00
(sizeof(_array) / sizeof(_array[0]))
/**
* Decoder test.
*
* This method will test the conversion only.
*/
nsresult testDecoder(nsIUnicodeDecoder * aDec,
const char * aSrc, PRInt32 aSrcLength,
const PRUnichar * aRes, PRInt32 aResLength,
const char * aTestName)
{
nsresult res;
// prepare for conversion
PRInt32 srcLen = aSrcLength;
1999-02-18 00:55:19 +00:00
PRUnichar dest[GENERAL_BUFFER/2];
PRInt32 destLen = GENERAL_BUFFER/2;
1999-02-12 19:50:47 +00:00
// conversion
res = aDec->Convert(dest, 0, &destLen, aSrc, 0, &srcLen);
1999-02-18 00:55:19 +00:00
// we want a perfect result here - the test data should be complete!
1999-02-12 19:50:47 +00:00
if (res != NS_OK) {
1999-02-24 16:27:30 +00:00
printf("ERROR at %s.easy.Decode() code=0x%x.\n",aTestName,res);
1999-02-12 19:50:47 +00:00
return NS_ERROR_UNEXPECTED;
}
// compare results
if (aResLength != destLen) {
1999-02-24 16:27:30 +00:00
printf("ERROR at %s.easy.DecResLen expected=0x%x result=0x%x.\n",
1999-02-12 19:50:47 +00:00
aTestName, aResLength, destLen);
return NS_ERROR_UNEXPECTED;
}
for (PRInt32 i=0; i<aResLength; i++) if (aRes[i] != dest[i]) {
1999-02-24 16:27:30 +00:00
printf("ERROR at %s.easy.DecResChar[%d] expected=0x%x result=0x%x.\n",
aTestName, i, aRes[i], dest[i]);
return NS_ERROR_UNEXPECTED;
}
return NS_OK;
}
/**
* Encoder test.
*
* This method will test the conversion only.
*/
nsresult testEncoder(nsIUnicodeEncoder * aEnc,
const PRUnichar * aSrc, PRInt32 aSrcLength,
const char * aRes, PRInt32 aResLength,
const char * aTestName)
{
nsresult res;
// prepare for conversion
PRInt32 srcLen = aSrcLength;
char dest[GENERAL_BUFFER];
PRInt32 destLen = GENERAL_BUFFER;
// conversion
res = aEnc->Convert(aSrc, &srcLen, dest, &destLen);
// we want a perfect result here - the test data should be complete!
if (res != NS_OK) {
printf("ERROR at %s.easy.Encode() code=0x%x.\n",aTestName,res);
return NS_ERROR_UNEXPECTED;
}
// compare results
if (aResLength != destLen) {
printf("ERROR at %s.easy.EncResLen expected=0x%x result=0x%x.\n",
aTestName, aResLength, destLen);
return NS_ERROR_UNEXPECTED;
}
for (PRInt32 i=0; i<aResLength; i++) if (aRes[i] != dest[i]) {
printf("ERROR at %s.easy.EncResChar[%d] expected=0x%x result=0x%x.\n",
1999-02-12 19:50:47 +00:00
aTestName, i, aRes[i], dest[i]);
return NS_ERROR_UNEXPECTED;
}
return NS_OK;
}
/**
* Decoder test.
*
* This method will test a given converter under a given set of data and some
* very stressful conditions.
*/
nsresult testStressDecoder(nsIUnicodeDecoder * aDec,
const char * aSrc, PRInt32 aSrcLength,
const PRUnichar * aRes, PRInt32 aResLength,
const char * aTestName)
{
nsresult res;
// get estimated length
PRInt32 estimatedLength;
res = aDec->Length(aSrc, 0, aSrcLength, &estimatedLength);
if (NS_FAILED(res)) {
printf("ERROR at %s.stress.Length() code=0x%x.\n",aTestName,res);
return res;
}
PRBool exactLength = (res == NS_EXACT_LENGTH);
// prepare for conversion
PRInt32 srcLen = 0;
PRInt32 srcOff = 0;
PRUnichar dest[1024];
PRInt32 destLen = 0;
PRInt32 destOff = 0;
// controlled conversion
for (;srcOff < aSrcLength;) {
res = aDec->Convert(dest, destOff, &destLen, aSrc, srcOff, &srcLen);
if (NS_FAILED(res)) {
printf("ERROR at %s.stress.Convert() code=0x%x.\n",aTestName,res);
return res;
}
srcOff+=srcLen;
destOff+=destLen;
// give a little input each time; it'll be consumed if enough output space
srcLen = 1;
// give output space only when requested: sadic!
if (res == NS_PARTIAL_MORE_OUTPUT) {
destLen = 1;
} else {
destLen = 0;
}
}
// we want perfect result here - the test data should be complete!
if (res != NS_OK) {
printf("ERROR at %s.stress.postConvert() code=0x%x.\n",aTestName,res);
return NS_ERROR_UNEXPECTED;
}
// compare lengths
if (exactLength) {
if (destOff != estimatedLength) {
printf("ERROR at %s.stress.EstimatedLen expected=0x%x result=0x%x.\n",
aTestName, estimatedLength, destOff);
return NS_ERROR_UNEXPECTED;
}
} else {
if (destOff > estimatedLength) {
printf("ERROR at %s.stress.EstimatedLen expected<=0x%x result=0x%x.\n",
aTestName, estimatedLength, destOff);
return NS_ERROR_UNEXPECTED;
}
}
// compare results
if (aResLength != destOff) {
printf("ERROR at %s.stress.ConvResLen expected=0x%x result=0x%x.\n",
aTestName, aResLength, destOff);
return NS_ERROR_UNEXPECTED;
}
for (PRInt32 i=0; i<aResLength; i++) if (aRes[i] != dest[i]) {
printf("ERROR at %s.stress.ConvResChar[%d] expected=0x%x result=0x%x.\n",
aTestName, i, aRes[i], dest[i]);
return NS_ERROR_UNEXPECTED;
}
return NS_OK;
}
1999-02-24 16:27:30 +00:00
/**
* Encoder test.
*
* This method will test a given converter under a given set of data and some
* very stressful conditions.
*/
nsresult testStressEncoder(nsIUnicodeEncoder * aEnc,
const PRUnichar * aSrc, PRInt32 aSrcLength,
const char * aRes, PRInt32 aResLength,
const char * aTestName)
{
nsresult res;
// get estimated length
PRInt32 estimatedLength;
res = aEnc->GetMaxLength(aSrc, aSrcLength, &estimatedLength);
if (NS_FAILED(res)) {
printf("ERROR at %s.stress.Length() code=0x%x.\n",aTestName,res);
return res;
}
PRBool exactLength = (res == NS_OK_UENC_EXACTLENGTH);
// prepare for conversion
PRInt32 srcLen = 0;
PRInt32 srcOff = 0;
char dest[GENERAL_BUFFER];
PRInt32 destLen = 0;
PRInt32 destOff = 0;
// controlled conversion
for (;srcOff < aSrcLength;) {
res = aEnc->Convert(aSrc + srcOff, &srcLen, dest + destOff, &destLen);
if (NS_FAILED(res)) {
printf("ERROR at %s.stress.Convert() code=0x%x.\n",aTestName,res);
return res;
}
srcOff+=srcLen;
destOff+=destLen;
// give a little input each time; it'll be consumed if enough output space
srcLen = 1;
// give output space only when requested: sadic!
if (res == NS_OK_UENC_MOREOUTPUT) {
destLen = 1;
} else {
destLen = 0;
}
}
if (res != NS_OK) if (res != NS_OK_UENC_MOREOUTPUT) {
printf("ERROR at %s.stress.postConvert() code=0x%x.\n",aTestName,res);
return NS_ERROR_UNEXPECTED;
} else for (;;) {
res = aEnc->Finish(dest + destOff, &destLen);
if (NS_FAILED(res)) {
printf("ERROR at %s.stress.Finish() code=0x%x.\n",aTestName,res);
return res;
}
destOff+=destLen;
// give output space only when requested: sadic!
if (res == NS_OK_UENC_MOREOUTPUT) {
destLen = 1;
} else break;
}
// compare lengths
if (exactLength) {
if (destOff != estimatedLength) {
printf("ERROR at %s.stress.EstimatedLen expected=0x%x result=0x%x.\n",
aTestName, estimatedLength, destOff);
return NS_ERROR_UNEXPECTED;
}
} else {
if (destOff > estimatedLength) {
printf("ERROR at %s.stress.EstimatedLen expected<=0x%x result=0x%x.\n",
aTestName, estimatedLength, destOff);
return NS_ERROR_UNEXPECTED;
}
}
// compare results
if (aResLength != destOff) {
printf("ERROR at %s.stress.ConvResLen expected=0x%x result=0x%x.\n",
aTestName, aResLength, destOff);
return NS_ERROR_UNEXPECTED;
}
for (PRInt32 i=0; i<aResLength; i++) if (aRes[i] != dest[i]) {
printf("ERROR at %s.stress.ConvResChar[%d] expected=0x%x result=0x%x.\n",
aTestName, i, aRes[i], dest[i]);
return NS_ERROR_UNEXPECTED;
}
return NS_OK;
}
1999-02-12 19:50:47 +00:00
/**
* Reset decoder.
*/
nsresult resetDecoder(nsIUnicodeDecoder * aDec, const char * aTestName)
{
nsresult res = aDec->Reset();
if (NS_FAILED(res)) {
1999-02-24 16:27:30 +00:00
printf("ERROR at %s.dec.Reset() code=0x%x.\n",aTestName,res);
return res;
}
return res;
}
/**
* Reset encoder.
*/
nsresult resetEncoder(nsIUnicodeEncoder * aEnc, const char * aTestName)
{
nsresult res = aEnc->Reset();
if (NS_FAILED(res)) {
printf("ERROR at %s.enc.Reset() code=0x%x.\n",aTestName,res);
1999-02-12 19:50:47 +00:00
return res;
}
return res;
}
1999-02-18 00:55:19 +00:00
nsresult loadBinaryFile(char * aFile, char * aBuff, PRInt32 * aBuffLen)
{
FILE * f = fopen(aFile, "rb");
if (f == NULL) {
printf("ERROR at opening file: \"%s\".\n", aFile);
return NS_ERROR_UNEXPECTED;
}
PRInt32 n = fread(aBuff, 1, *aBuffLen, f);
if (n >= *aBuffLen) {
printf("ERROR at reading from file \"%s\": too much input data.\n", aFile);
return NS_ERROR_UNEXPECTED;
}
*aBuffLen = n;
fclose(f);
return NS_OK;
}
nsresult loadUnicodeFile(char * aFile, PRUnichar * aBuff, PRInt32 * aBuffLen)
{
PRInt32 buffLen = 2*(*aBuffLen);
nsresult res = loadBinaryFile(aFile, (char *)aBuff, &buffLen);
if (NS_FAILED(res)) return res;
*aBuffLen = buffLen/2;
return NS_OK;
}
nsresult testDecoderFromFiles(char * aCharset, char * aSrcFile, char * aResultFile)
{
// create converter
CREATE_DECODER(aCharset);
PRInt32 srcLen = GENERAL_BUFFER;
char src[GENERAL_BUFFER];
PRInt32 expLen = GENERAL_BUFFER/2;
PRUnichar exp[GENERAL_BUFFER/2];
res = loadBinaryFile(aSrcFile, src, &srcLen);
if (NS_FAILED(res)) return res;
res = loadUnicodeFile(aResultFile, exp, &expLen);
if (NS_FAILED(res)) return res;
// test converter - easy test
res = testDecoder(dec, src, srcLen, exp, expLen, "dec");
// release converter
NS_RELEASE(dec);
if (NS_FAILED(res)) {
return res;
} else {
printf("Test Passed.\n");
return NS_OK;
}
return NS_OK;
}
nsresult testEncoderFromFiles(char * aCharset, char * aSrcFile, char * aResultFile)
{
// XXX write me
return NS_OK;
}
1999-02-12 19:50:47 +00:00
//----------------------------------------------------------------------
// Decoders testing functions
/**
* Test the Latin1 decoder.
*/
nsresult testLatin1Decoder()
{
1999-02-18 00:55:19 +00:00
char * testName = "T101";
1999-02-12 19:50:47 +00:00
printf("\n[%s] Latin1ToUnicode\n", testName);
// create converter
CREATE_DECODER("iso-8859-1");
// test data
char src[] = {"\x00\x0d\x7f\x80\xff"};
1999-03-23 18:49:32 +00:00
PRUnichar exp[] = {0x0000,0x000d,0xfffd,0xfffd,0x00ff};
1999-02-12 19:50:47 +00:00
// test converter - easy test
res = testDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
// reset converter
if (NS_SUCCEEDED(res)) res = resetDecoder(dec, testName);
// test converter - stress test
if (NS_SUCCEEDED(res))
res = testStressDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
// release converter
NS_RELEASE(dec);
if (NS_FAILED(res)) {
return res;
} else {
printf("Test Passed.\n");
return NS_OK;
}
}
/**
* Test the ISO2022JP decoder.
*/
nsresult testISO2022JPDecoder()
{
1999-02-18 00:55:19 +00:00
char * testName = "T102";
1999-02-12 19:50:47 +00:00
printf("\n[%s] ISO2022JPToUnicode\n", testName);
// create converter
CREATE_DECODER("iso-2022-jp");
// test data
char src[] = {"\x0d\x7f\xdd" "\x1b(J\xaa\xdc\x41" "\x1b$B\x21\x21" "\x1b$@\x32\x37" "\x1b(J\x1b(B\xcc"};
PRUnichar exp[] = {0x000d,0x007f,0xfffd, 0xff6a,0xFF9C,0x0041, 0x3000, 0x5378, 0xfffd};
// test converter - normal operation
res = testDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
// reset converter
if (NS_SUCCEEDED(res)) res = resetDecoder(dec, testName);
// test converter - stress test
if (NS_SUCCEEDED(res))
res = testStressDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
// release converter
NS_RELEASE(dec);
if (NS_FAILED(res)) {
return res;
} else {
printf("Test Passed.\n");
return NS_OK;
}
}
1999-03-11 20:39:50 +00:00
/**
* Test the EUCJP decoder.
*/
nsresult testEUCJPDecoder()
{
char * testName = "T103";
printf("\n[%s] EUCJPToUnicode\n", testName);
// create converter
CREATE_DECODER("euc-jp");
// test data
char src[] = {"\x45"};
PRUnichar exp[] = {0x0045};
// test converter - normal operation
res = testDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
#ifdef NOPE // XXX decomment this when the decoder can take this test.
// reset converter
if (NS_SUCCEEDED(res)) res = resetDecoder(dec, testName);
// test converter - stress test
if (NS_SUCCEEDED(res))
res = testStressDecoder(dec, src, ARRAY_SIZE(src)-1, exp, ARRAY_SIZE(exp), testName);
#endif
// release converter
NS_RELEASE(dec);
if (NS_FAILED(res)) {
return res;
} else {
printf("Test Passed.\n");
return NS_OK;
}
}
1999-02-12 19:50:47 +00:00
//----------------------------------------------------------------------
// Encoders testing functions
1999-02-18 00:55:19 +00:00
/**
* Test the Latin1 encoder.
*/
nsresult testLatin1Encoder()
{
char * testName = "T201";
printf("\n[%s] UnicodeToLatin1\n", testName);
// create converter
CREATE_ENCODER("iso-8859-1");
1999-02-24 16:27:30 +00:00
enc->SetOutputErrorBehavior(enc->kOnError_Replace, NULL, 0x00cc);
1999-02-18 00:55:19 +00:00
// test data
1999-02-24 16:27:30 +00:00
PRUnichar src[] = {0x0001,0x0002,0xffff,0x00e3};
char exp[] = {"\x01\x02\xcc\xe3"};
1999-02-18 00:55:19 +00:00
// test converter - easy test
1999-02-24 16:27:30 +00:00
res = testEncoder(enc, src, ARRAY_SIZE(src), exp, ARRAY_SIZE(exp)-1, testName);
1999-02-18 00:55:19 +00:00
// reset converter
1999-02-24 16:27:30 +00:00
if (NS_SUCCEEDED(res)) res = resetEncoder(enc, testName);
1999-02-18 00:55:19 +00:00
// test converter - stress test
if (NS_SUCCEEDED(res))
1999-02-24 16:27:30 +00:00
res = testStressEncoder(enc, src, ARRAY_SIZE(src), exp, ARRAY_SIZE(exp)-1, testName);
1999-02-18 00:55:19 +00:00
// release converter
NS_RELEASE(enc);
if (NS_FAILED(res)) {
return res;
} else {
printf("Test Passed.\n");
return NS_OK;
}
}
1999-03-11 21:04:30 +00:00
/**
* Test the Shift-JIS encoder.
*/
nsresult testSJISEncoder()
{
char * testName = "T202";
printf("\n[%s] UnicodeToSJIS\n", testName);
// create converter
CREATE_ENCODER("Shift_JIS");
enc->SetOutputErrorBehavior(enc->kOnError_Replace, NULL, 0x00cc);
// test data
PRUnichar src[] = {
0x004A, 0x0061, 0x0070, 0x0061, 0x006E, 0x0065, 0x0073, 0x0065,
0x6f22, 0x5b57,
0x30ab, 0x30bf, 0x30ab, 0x30ca,
0x3072, 0x3089, 0x304c, 0x306a,
0xff11, 0xff12, 0xff13, 0xff21, 0xff22, 0xff23
};
char exp[] = {
"Japanese" /* English */
"\x8a\xbf\x8e\x9a" /* Kanji */
"\x83\x4a\x83\x5e\x83\x4a\x83\x69" /* Kantakana */
"\x82\xd0\x82\xe7\x82\xaa\x82\xc8" /* Hiragana */
"\x82\x50\x82\x51\x82\x52\x82\x60\x82\x61\x82\x62" /* full width 123ABC */
};
// test converter - easy test
res = testEncoder(enc, src, ARRAY_SIZE(src), exp, ARRAY_SIZE(exp)-1, testName);
// reset converter
if (NS_SUCCEEDED(res)) res = resetEncoder(enc, testName);
// test converter - stress test
if (NS_SUCCEEDED(res))
res = testStressEncoder(enc, src, ARRAY_SIZE(src), exp, ARRAY_SIZE(exp)-1, testName);
// release converter
NS_RELEASE(enc);
if (NS_FAILED(res)) {
return res;
} else {
printf("Test Passed.\n");
return NS_OK;
}
}
1999-03-11 22:37:53 +00:00
/**
* Test the EUC-JP encoder.
*/
nsresult testEUCJPEncoder()
{
char * testName = "T203";
printf("\n[%s] UnicodeToEUCJP\n", testName);
// create converter
CREATE_ENCODER("euc-jp");
enc->SetOutputErrorBehavior(enc->kOnError_Replace, NULL, 0x00cc);
// test data
PRUnichar src[] = {0x0045, 0x0054};
char exp[] = {"\x45\x54"};
// test converter - easy test
res = testEncoder(enc, src, ARRAY_SIZE(src), exp, ARRAY_SIZE(exp)-1, testName);
// reset converter
if (NS_SUCCEEDED(res)) res = resetEncoder(enc, testName);
// test converter - stress test
if (NS_SUCCEEDED(res))
res = testStressEncoder(enc, src, ARRAY_SIZE(src), exp, ARRAY_SIZE(exp)-1, testName);
// release converter
NS_RELEASE(enc);
if (NS_FAILED(res)) {
return res;
} else {
printf("Test Passed.\n");
return NS_OK;
}
}
nsresult testPlatformCharset()
{
nsIPlatformCharset * cinfo;
nsresult res = nsServiceManager::GetService(kPlatformCharsetCID,
kIPlatformCharsetIID, (nsISupports **)&cinfo);
if (NS_FAILED(res)) {
printf("ERROR at GetService() code=0x%x.\n",res);
return res;
}
nsString value;
res = cinfo->GetCharset(kPlatformCharsetSel_PlainTextInClipboard , value);
1999-02-25 14:46:46 +00:00
printf("Clipboard plain text encoding = %s\n",value.ToNewCString());
res = cinfo->GetCharset(kPlatformCharsetSel_FileName , value);
1999-02-25 14:46:46 +00:00
printf("File Name encoding = %s\n",value.ToNewCString());
res = cinfo->GetCharset(kPlatformCharsetSel_Menu , value);
1999-02-25 14:46:46 +00:00
printf("Menu encoding = %s\n",value.ToNewCString());
cinfo->Release();
return res;
}
1999-02-12 19:50:47 +00:00
//----------------------------------------------------------------------
1999-02-18 00:55:19 +00:00
// Testing functions
1999-02-18 00:55:19 +00:00
nsresult testAll()
{
nsresult res;
1999-02-12 19:50:47 +00:00
// test the manager(s)
res = testCharsetConverterManager();
if (NS_FAILED(res)) return res;
testPlatformCharset();
1999-02-12 19:50:47 +00:00
// test decoders
testLatin1Decoder();
testISO2022JPDecoder();
1999-03-11 20:39:50 +00:00
testEUCJPDecoder();
1999-01-14 23:23:30 +00:00
1999-02-12 19:50:47 +00:00
// test encoders
1999-02-18 00:55:19 +00:00
testLatin1Encoder();
1999-03-11 21:04:30 +00:00
testSJISEncoder();
1999-03-11 22:37:53 +00:00
testEUCJPEncoder();
1999-02-18 00:55:19 +00:00
// older tests - XXX to be rewritten in new style
testSJISDecoder();
testISO88597Decoder();
1999-01-14 23:23:30 +00:00
1999-02-12 19:50:47 +00:00
// return
return NS_OK;
}
1999-01-12 08:35:45 +00:00
1999-02-18 00:55:19 +00:00
nsresult testFromArgs(int argc, char **argv)
{
nsresult res = nsServiceManager::GetService(kCharsetConverterManagerCID,
kICharsetConverterManagerIID, (nsISupports **)&ccMan);
if (NS_FAILED(res)) {
printf("ERROR at GetService() code=0x%x.\n",res);
return res;
}
if ((argc == 5) && (!strcmp(argv[1], "-tdec"))) {
res = testDecoderFromFiles(argv[2], argv[3], argv[4]);
} else if ((argc == 5) && (!strcmp(argv[1], "-tenc"))) {
res = testEncoderFromFiles(argv[2], argv[3], argv[4]);
} else {
printf("Usage:\n");
printf(" TestUConv.exe\n");
printf(" TestUConv.exe -tdec encoding inputEncodedFile expectedResultUnicodeFile\n");
printf(" TestUConv.exe -tenc encoding inputUnicodeFile expectedResultEncodedFile\n");
}
return res;
}
//----------------------------------------------------------------------
// Main program functions
1999-02-12 19:50:47 +00:00
nsresult init()
{
nsresult res;
1999-02-12 19:50:47 +00:00
res = setupRegistry();
if (NS_FAILED(res)) {
1999-02-18 00:55:19 +00:00
printf("ERROR at setupRegistry() code=0x%x.\n", res);
1999-02-12 19:50:47 +00:00
return res;
}
return NS_OK;
}
nsresult done()
{
1999-02-18 00:55:19 +00:00
if (ccMan != NULL) nsServiceManager::
ReleaseService(kCharsetConverterManagerCID, ccMan);
return NS_OK;
}
int main(int argc, char **argv)
{
nsresult res;
res = init();
if (NS_FAILED(res)) return -1;
1999-02-18 00:55:19 +00:00
if (argc <= 1) {
printf("*** Unicode Converters Test ***\n");
res = testAll();
printf("\n***--------- Done --------***\n");
} else {
res = testFromArgs(argc, argv);
}
done();
1999-02-18 00:55:19 +00:00
if (NS_FAILED(res)) return -1;
else return 0;
}