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();
88