зеркало из https://github.com/mozilla/pjs.git
101 строка
2.9 KiB
JavaScript
101 строка
2.9 KiB
JavaScript
/*
|
|
* 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');
|
|
}
|