summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/RegExp/unicode_restricted_quantifiable_assertion.js
blob: 988dac42f1bea167492cb3638072083eaf16864b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
// Copyright (C) 2015 André Bargull. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.

/*---
description: B.1.4 is not applied for Unicode RegExp - Production 'QuantifiableAssertion Quantifier'
info: |
    The compatibility extensions defined in B.1.4 Regular Expressions Patterns
    are not applied for Unicode RegExps.
    Tested extension: "ExtendedTerm :: QuantifiableAssertion Quantifier"
es6id: 21.1.2
---*/

// Positive lookahead with quantifier.
assert.throws(SyntaxError, function() {
  RegExp("(?=.)*", "u");
}, 'RegExp("(?=.)*", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.)+", "u");
}, 'RegExp("(?=.)+", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.)?", "u");
}, 'RegExp("(?=.)?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.){1}", "u");
}, 'RegExp("(?=.){1}", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.){1,}", "u");
}, 'RegExp("(?=.){1,}", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.){1,2}", "u");
}, 'RegExp("(?=.){1,2}", "u"): ');


// Positive lookahead with reluctant quantifier.
assert.throws(SyntaxError, function() {
  RegExp("(?=.)*?", "u");
}, 'RegExp("(?=.)*?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.)+?", "u");
}, 'RegExp("(?=.)+?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.)??", "u");
}, 'RegExp("(?=.)??", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.){1}?", "u");
}, 'RegExp("(?=.){1}?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.){1,}?", "u");
}, 'RegExp("(?=.){1,}?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?=.){1,2}?", "u");
}, 'RegExp("(?=.){1,2}?", "u"): ');


// Negative lookahead with quantifier.
assert.throws(SyntaxError, function() {
  RegExp("(?!.)*", "u");
}, 'RegExp("(?!.)*", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.)+", "u");
}, 'RegExp("(?!.)+", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.)?", "u");
}, 'RegExp("(?!.)?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.){1}", "u");
}, 'RegExp("(?!.){1}", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.){1,}", "u");
}, 'RegExp("(?!.){1,}", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.){1,2}", "u");
}, 'RegExp("(?!.){1,2}", "u"): ');


// Negative lookahead with reluctant quantifier.
assert.throws(SyntaxError, function() {
  RegExp("(?!.)*?", "u");
}, 'RegExp("(?!.)*?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.)+?", "u");
}, 'RegExp("(?!.)+?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.)??", "u");
}, 'RegExp("(?!.)??", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.){1}?", "u");
}, 'RegExp("(?!.){1}?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.){1,}?", "u");
}, 'RegExp("(?!.){1,}?", "u"): ');
assert.throws(SyntaxError, function() {
  RegExp("(?!.){1,2}?", "u");
}, 'RegExp("(?!.){1,2}?", "u"): ');

reportCompare(0, 0);