initial import
[vuplus_webkit] / Source / JavaScriptCore / tests / mozilla / js1_2 / regexp / plus.js
1 /* The contents of this file are subject to the Netscape Public
2  * License Version 1.1 (the "License"); you may not use this file
3  * except in compliance with the License. You may obtain a copy of
4  * the License at http://www.mozilla.org/NPL/
5  *
6  * Software distributed under the License is distributed on an "AS
7  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
8  * implied. See the License for the specific language governing
9  * rights and limitations under the License.
10  *
11  * The Original Code is Mozilla Communicator client code, released March
12  * 31, 1998.
13  *
14  * The Initial Developer of the Original Code is Netscape Communications
15  * Corporation. Portions created by Netscape are
16  * Copyright (C) 1998 Netscape Communications Corporation. All
17  * Rights Reserved.
18  *
19  * Contributor(s): 
20  * 
21  */
22 /**
23         Filename:     plus.js
24         Description:  'Tests regular expressions containing +'
25
26         Author:       Nick Lerissa
27         Date:         March 10, 1998
28 */
29
30         var SECTION = 'As described in Netscape doc "Whats new in JavaScript 1.2"';
31         var VERSION = 'no version';
32     startTest();
33         var TITLE   = 'RegExp: +';
34
35         writeHeaderToLog('Executing script: plus.js');
36         writeHeaderToLog( SECTION + " "+ TITLE);
37
38         var count = 0;
39         var testcases = new Array();
40
41     // 'abcdddddefg'.match(new RegExp('d+'))
42         testcases[count++] = new TestCase ( SECTION, "'abcdddddefg'.match(new RegExp('d+'))",
43                                             String(["ddddd"]), String('abcdddddefg'.match(new RegExp('d+'))));
44
45     // 'abcdefg'.match(new RegExp('o+'))
46         testcases[count++] = new TestCase ( SECTION, "'abcdefg'.match(new RegExp('o+'))",
47                                             null, 'abcdefg'.match(new RegExp('o+')));
48
49     // 'abcdefg'.match(new RegExp('d+'))
50         testcases[count++] = new TestCase ( SECTION, "'abcdefg'.match(new RegExp('d+'))",
51                                             String(['d']), String('abcdefg'.match(new RegExp('d+'))));
52
53     // 'abbbbbbbc'.match(new RegExp('(b+)(b+)(b+)'))
54         testcases[count++] = new TestCase ( SECTION, "'abbbbbbbc'.match(new RegExp('(b+)(b+)(b+)'))",
55                                             String(["bbbbbbb","bbbbb","b","b"]), String('abbbbbbbc'.match(new RegExp('(b+)(b+)(b+)'))));
56
57     // 'abbbbbbbc'.match(new RegExp('(b+)(b*)'))
58         testcases[count++] = new TestCase ( SECTION, "'abbbbbbbc'.match(new RegExp('(b+)(b*)'))",
59                                             String(["bbbbbbb","bbbbbbb",""]), String('abbbbbbbc'.match(new RegExp('(b+)(b*)'))));
60
61     // 'abbbbbbbc'.match(new RegExp('b*b+'))
62         testcases[count++] = new TestCase ( SECTION, "'abbbbbbbc'.match(new RegExp('b*b+'))",
63                                             String(['bbbbbbb']), String('abbbbbbbc'.match(new RegExp('b*b+'))));
64
65     // 'abbbbbbbc'.match(/(b+)(b*)/)
66         testcases[count++] = new TestCase ( SECTION, "'abbbbbbbc'.match(/(b+)(b*)/)",
67                                             String(["bbbbbbb","bbbbbbb",""]), String('abbbbbbbc'.match(/(b+)(b*)/)));
68
69     // 'abbbbbbbc'.match(new RegExp('b*b+'))
70         testcases[count++] = new TestCase ( SECTION, "'abbbbbbbc'.match(/b*b+/)",
71                                             String(['bbbbbbb']), String('abbbbbbbc'.match(/b*b+/)));
72
73         function test()
74         {
75            for ( tc=0; tc < testcases.length; tc++ ) {
76                 testcases[tc].passed = writeTestCaseResult(
77                 testcases[tc].expect,
78                 testcases[tc].actual,
79                 testcases[tc].description +" = "+
80                 testcases[tc].actual );
81                 testcases[tc].reason += ( testcases[tc].passed ) ? "" : "wrong value ";
82            }
83            stopTest();
84            return ( testcases );
85         }
86
87         test();