| /* |
| * 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'); |
| } |