Imported Upstream version 1.0.0
[platform/upstream/js.git] / js / src / tests / js1_2 / regexp / word_boundary.js
1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
4  *
5  * The contents of this file are subject to the Mozilla Public License Version
6  * 1.1 (the "License"); you may not use this file except in compliance with
7  * the License. You may obtain a copy of the License at
8  * http://www.mozilla.org/MPL/
9  *
10  * Software distributed under the License is distributed on an "AS IS" basis,
11  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12  * for the specific language governing rights and limitations under the
13  * License.
14  *
15  * The Original Code is Mozilla Communicator client code, released
16  * March 31, 1998.
17  *
18  * The Initial Developer of the Original Code is
19  * Netscape Communications Corporation.
20  * Portions created by the Initial Developer are Copyright (C) 1998
21  * the Initial Developer. All Rights Reserved.
22  *
23  * Contributor(s):
24  *
25  * Alternatively, the contents of this file may be used under the terms of
26  * either the GNU General Public License Version 2 or later (the "GPL"), or
27  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
28  * in which case the provisions of the GPL or the LGPL are applicable instead
29  * of those above. If you wish to allow use of your version of this file only
30  * under the terms of either the GPL or the LGPL, and not to allow others to
31  * use your version of this file under the terms of the MPL, indicate your
32  * decision by deleting the provisions above and replace them with the notice
33  * and other provisions required by the GPL or the LGPL. If you do not delete
34  * the provisions above, a recipient may use your version of this file under
35  * the terms of any one of the MPL, the GPL or the LGPL.
36  *
37  * ***** END LICENSE BLOCK ***** */
38
39
40 /**
41    Filename:     word_boundary.js
42    Description:  'Tests regular expressions containing \b and \B'
43
44    Author:       Nick Lerissa
45    Date:         March 10, 1998
46 */
47
48 var SECTION = 'As described in Netscape doc "Whats new in JavaScript 1.2"';
49 var VERSION = 'no version';
50 startTest();
51 var TITLE   = 'RegExp: \\b and \\B';
52
53 writeHeaderToLog('Executing script: word_boundary.js');
54 writeHeaderToLog( SECTION + " "+ TITLE);
55
56
57 // 'cowboy boyish boy'.match(new RegExp('\bboy\b'))
58 new TestCase ( SECTION, "'cowboy boyish boy'.match(new RegExp('\\bboy\\b'))",
59                String(["boy"]), String('cowboy boyish boy'.match(new RegExp('\\bboy\\b'))));
60
61 var boundary_characters = "\f\n\r\t\v~`!@#$%^&*()-+={[}]|\\:;'<,>./? " + '"';
62 var non_boundary_characters = '1234567890_abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
63 var s     = '';
64 var i;
65
66 // testing whether all boundary characters are matched when they should be
67 for (i = 0; i < boundary_characters.length; ++i)
68 {
69   s = '123ab' + boundary_characters.charAt(i) + '123c' + boundary_characters.charAt(i);
70
71   new TestCase ( SECTION,
72                  "'" + s + "'.match(new RegExp('\\b123[a-z]\\b'))",
73                  String(["123c"]), String(s.match(new RegExp('\\b123[a-z]\\b'))));
74 }
75
76 // testing whether all non-boundary characters are matched when they should be
77 for (i = 0; i < non_boundary_characters.length; ++i)
78 {
79   s = '123ab' + non_boundary_characters.charAt(i) + '123c' + non_boundary_characters.charAt(i);
80
81   new TestCase ( SECTION,
82                  "'" + s + "'.match(new RegExp('\\B123[a-z]\\B'))",
83                  String(["123c"]), String(s.match(new RegExp('\\B123[a-z]\\B'))));
84 }
85
86 s = '';
87
88 // testing whether all boundary characters are not matched when they should not be
89 for (i = 0; i < boundary_characters.length; ++i)
90 {
91   s += boundary_characters[i] + "a" + i + "b";
92 }
93 s += "xa1111bx";
94
95 new TestCase ( SECTION,
96                "'" + s + "'.match(new RegExp('\\Ba\\d+b\\B'))",
97                String(["a1111b"]), String(s.match(new RegExp('\\Ba\\d+b\\B'))));
98
99 new TestCase ( SECTION,
100                "'" + s + "'.match(/\\Ba\\d+b\\B/)",
101                String(["a1111b"]), String(s.match(/\Ba\d+b\B/)));
102
103 s = '';
104
105 // testing whether all non-boundary characters are not matched when they should not be
106 for (i = 0; i < non_boundary_characters.length; ++i)
107 {
108   s += non_boundary_characters[i] + "a" + i + "b";
109 }
110 s += "(a1111b)";
111
112 new TestCase ( SECTION,
113                "'" + s + "'.match(new RegExp('\\ba\\d+b\\b'))",
114                String(["a1111b"]), String(s.match(new RegExp('\\ba\\d+b\\b'))));
115
116 new TestCase ( SECTION,
117                "'" + s + "'.match(/\\ba\\d+b\\b/)",
118                String(["a1111b"]), String(s.match(/\ba\d+b\b/)));
119
120 test();