/* * The contents of this file are subject to the Netscape Public * License Version 1.1 (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 expressed * or implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is mozilla.org 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. * * Contributor(s): pschwartau@netscape.com * Date: 2001-07-17 * * SUMMARY: Regression test for Bugzilla bug 72964: * "String method for pattern matching failed for Chinese Simplified (GB2312)" * * See http://bugzilla.mozilla.org/show_bug.cgi?id=72964 */ //----------------------------------------------------------------------------- var i = 0; var bug = 72964; var summary = 'Testing regular expressions containing non-Latin1 characters'; var cnSingleSpace = ' '; var status = ''; var statusmessages = new Array(); var pattern = ''; var patterns = new Array(); var string = ''; var strings = new Array(); var actualmatch = ''; var actualmatches = new Array(); var expectedmatch = ''; var expectedmatches = new Array(); pattern = /[\S]+/; // 4 low Unicode chars = Latin1; whole string should match status = inSection(1); string = '\u00BF\u00CD\u00BB\u00A7'; actualmatch = string.match(pattern); expectedmatch = Array(string); addThis(); // Now put a space in the middle; first half of string should match status = inSection(2); string = '\u00BF\u00CD \u00BB\u00A7'; actualmatch = string.match(pattern); expectedmatch = Array('\u00BF\u00CD'); addThis(); // 4 high Unicode chars = non-Latin1; whole string should match status = inSection(3); string = '\u4e00\uac00\u4e03\u4e00'; actualmatch = string.match(pattern); expectedmatch = Array(string); addThis(); // Now put a space in the middle; first half of string should match status = inSection(4); string = '\u4e00\uac00 \u4e03\u4e00'; actualmatch = string.match(pattern); expectedmatch = Array('\u4e00\uac00'); addThis(); //----------------------------------------------------------------------------- test(); //----------------------------------------------------------------------------- function addThis() { statusmessages[i] = status; patterns[i] = pattern; strings[i] = string; actualmatches[i] = actualmatch; expectedmatches[i] = expectedmatch; i++; } function test() { enterFunc ('test'); printBugNumber (bug); printStatus (summary); testRegExp(statusmessages, patterns, strings, actualmatches, expectedmatches); exitFunc ('test'); }