tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

character-class-digit-class-escape-negative-cases.js (2245B)


      1 // Copyright (C) 2018 Leo Balter.  All rights reserved.
      2 // Copyright (C) 2024 Aurèle Barrière.  All rights reserved.
      3 // This code is governed by the BSD license found in the LICENSE file.
      4 
      5 /*---
      6 esid: prod-CharacterClassEscape
      7 description: >
      8  Check negative cases of digit class escape \d.
      9 info: |
     10  This is a generated test. Please check out
     11  https://github.com/tc39/test262/tree/main/tools/regexp-generator/
     12  for any changes.
     13 
     14  CharacterClassEscape[UnicodeMode] ::
     15    d
     16    D
     17    s
     18    S
     19    w
     20    W
     21    [+UnicodeMode] p{ UnicodePropertyValueExpression }
     22    [+UnicodeMode] P{ UnicodePropertyValueExpression }
     23 
     24  22.2.2.9 Runtime Semantics: CompileToCharSet
     25 
     26  CharacterClassEscape :: d
     27    1. Return the ten-element CharSet containing the characters 0, 1, 2, 3, 4,
     28      5, 6, 7, 8, and 9.
     29  CharacterClassEscape :: D
     30    1. Let S be the CharSet returned by CharacterClassEscape :: d.
     31    2. Return CharacterComplement(rer, S).
     32  CharacterClassEscape :: s
     33    1. Return the CharSet containing all characters corresponding to a code
     34      point on the right-hand side of the WhiteSpace or LineTerminator
     35      productions.
     36  CharacterClassEscape :: S
     37    1. Let S be the CharSet returned by CharacterClassEscape :: s.
     38    2. Return CharacterComplement(rer, S).
     39  CharacterClassEscape :: w
     40    1. Return MaybeSimpleCaseFolding(rer, WordCharacters(rer)).
     41  CharacterClassEscape :: W
     42    1. Let S be the CharSet returned by CharacterClassEscape :: w.
     43    2. Return CharacterComplement(rer, S).
     44 features: [String.fromCodePoint]
     45 includes: [regExpUtils.js]
     46 flags: [generated]
     47 ---*/
     48 
     49 const str = buildString(
     50 {
     51  loneCodePoints: [],
     52  ranges: [
     53    [0x00DC00, 0x00DFFF],
     54    [0x000000, 0x00002F],
     55    [0x00003A, 0x00DBFF],
     56    [0x00E000, 0x10FFFF]
     57  ]
     58 }
     59 );
     60 
     61 const standard = /\d/;
     62 const unicode = /\d/u;
     63 const vflag = /\d/v;
     64 const regexes = [standard,unicode,vflag];
     65 
     66 const errors = [];
     67 
     68 for (const regex of regexes) {
     69  if (regex.test(str)) {
     70    // Error, let's find out where
     71    for (const char of str) {
     72      if (regex.test(char)) {
     73        errors.push('0x' + char.codePointAt(0).toString(16));
     74      }
     75    }
     76  }
     77 }
     78 
     79 assert.sameValue(
     80  errors.length,
     81  0,
     82  'Expected no match, but matched: ' + errors.join(',')
     83 );
     84 
     85 reportCompare(0, 0);