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:     string_split.js
24	Description:  'Tests the split method on Strings using regular expressions'
25
26	Author:       Nick Lerissa
27	Date:         March 11, 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   = 'String: split';
34
35	writeHeaderToLog('Executing script: string_split.js');
36	writeHeaderToLog( SECTION + " "+ TITLE);
37
38	var count = 0;
39	var testcases = new Array();
40
41    // 'a b c de f'.split(/\s/)
42	testcases[count++] = new TestCase ( SECTION, "'a b c de f'.split(/\s/)",
43	                                    String(["a","b","c","de","f"]), String('a b c de f'.split(/\s/)));
44
45    // 'a b c de f'.split(/\s/,3)
46	testcases[count++] = new TestCase ( SECTION, "'a b c de f'.split(/\s/,3)",
47	                                    String(["a","b","c"]), String('a b c de f'.split(/\s/,3)));
48
49    // 'a b c de f'.split(/X/)
50	testcases[count++] = new TestCase ( SECTION, "'a b c de f'.split(/X/)",
51	                                    String(["a b c de f"]), String('a b c de f'.split(/X/)));
52
53    // 'dfe23iu 34 =+65--'.split(/\d+/)
54	testcases[count++] = new TestCase ( SECTION, "'dfe23iu 34 =+65--'.split(/\d+/)",
55	                                    String(["dfe","iu "," =+","--"]), String('dfe23iu 34 =+65--'.split(/\d+/)));
56
57    // 'dfe23iu 34 =+65--'.split(new RegExp('\d+'))
58	testcases[count++] = new TestCase ( SECTION, "'dfe23iu 34 =+65--'.split(new RegExp('\\d+'))",
59	                                    String(["dfe","iu "," =+","--"]), String('dfe23iu 34 =+65--'.split(new RegExp('\\d+'))));
60
61    // 'abc'.split(/[a-z]/)
62	testcases[count++] = new TestCase ( SECTION, "'abc'.split(/[a-z]/)",
63	                                    String(["","",""]), String('abc'.split(/[a-z]/)));
64
65    // 'abc'.split(/[a-z]/)
66	testcases[count++] = new TestCase ( SECTION, "'abc'.split(/[a-z]/)",
67	                                    String(["","",""]), String('abc'.split(/[a-z]/)));
68
69    // 'abc'.split(new RegExp('[a-z]'))
70	testcases[count++] = new TestCase ( SECTION, "'abc'.split(new RegExp('[a-z]'))",
71	                                    String(["","",""]), String('abc'.split(new RegExp('[a-z]'))));
72
73    // 'abc'.split(new RegExp('[a-z]'))
74	testcases[count++] = new TestCase ( SECTION, "'abc'.split(new RegExp('[a-z]'))",
75	                                    String(["","",""]), String('abc'.split(new RegExp('[a-z]'))));
76
77function test()
78	{
79	   for ( tc=0; tc < testcases.length; tc++ ) {
80	        testcases[tc].passed = writeTestCaseResult(
81	        testcases[tc].expect,
82	        testcases[tc].actual,
83	        testcases[tc].description +" = "+
84	        testcases[tc].actual );
85	        testcases[tc].reason += ( testcases[tc].passed ) ? "" : "wrong value ";
86	   }
87	   stopTest();
88	   return ( testcases );
89	}
90
91	test();
92