v8/test/mjsunit/harmony/numeric-separator.js
Joshua Litt af4a7dc312 [scanner] fix edge case for parsing numeric separators
Numeric separators are not allowed in NonOctalDecimalIntegerLiterals.

Bug: v8:9437
Change-Id: Ic62b35b361de36fc622e207c140c365665021029
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1722194
Commit-Queue: Joshua Litt <joshualitt@chromium.org>
Reviewed-by: Sathya Gunasekaran <gsathya@chromium.org>
Cr-Commit-Position: refs/heads/master@{#62994}
2019-07-30 17:06:29 +00:00

116 lines
2.8 KiB
JavaScript

// Copyright 2016 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --harmony-numeric-separator
{
const basic = 1_0_0_0;
assertEquals(basic, 1000);
}
{
const exponent = 1_0e+1;
assertEquals(exponent, 10e+1);
}
{
const exponent2 = 1_0e+1_0;
assertEquals(exponent2, 10e+10);
}
{
const hex = 0xF_F_FF;
assertEquals(hex, 0xFFFF);
}
{
const octal = 0o7_7_7;
assertEquals(octal, 0o777);
}
{
let exception = false;
try {
const code = `"use strict" const implicitOctal = 07_7_7`;
eval(code);
} catch(e) {
exception = true;
assertInstanceof(e, SyntaxError);
}
assertTrue(exception);
}
{
const binary = 0b0_1_0_1_0;
assertEquals(binary, 0b01010);
}
{
const dot1 = 9_1.1_3;
assertEquals(dot1, 91.13);
const dot2 = 1.1_3;
assertEquals(dot2, 1.13);
const dot3 = 1_1.21;
assertEquals(dot3, 11.21);
const dot4 = 09.1_2
assertEquals(dot4, 9.12);
}
{
const basic = Number('1_2_3');
assertEquals(NaN, basic);
const exponent = Number('1_0e+1');
assertEquals(NaN, exponent);
const exponent2 = Number('1_0e+1_0');
assertEquals(NaN, exponent2);
const hex = Number('0xF_F_FF');
assertEquals(NaN, hex);
const octal = Number('0o7_7_7');
assertEquals(NaN, octal);
const binary = Number('0b0_1_0_1_0');
assertEquals(NaN, binary);
const leadingZeros = Number('09_1_3');
assertEquals(NaN, leadingZeros);
const dot1 = Number('9_1.1_3');
assertEquals(NaN, dot1);
const dot2 = Number('1.1_3');
assertEquals(NaN, dot2);
const dot3 = Number('1_1.21');
assertEquals(NaN, dot3);
}
{
assertEquals(1, parseInt('1_2_3'));
assertEquals(0, parseInt('0_1_0_1_0'));
assertEquals(15, parseInt('0xF_F'));
assertEquals(10, parseInt('10e+1_0'));
assertEquals(0, parseInt('0o7_7_7'));
assertEquals(0, parseInt('0b1_0_1_0'));
assertEquals(9, parseInt('9_1.1_3'));
assertEquals(1, parseInt('1.1_3'));
assertEquals(1, parseInt('1_1.21'));
assertEquals(17, parseInt('017_123'));
assertEquals(1, parseInt('1_2_3', 10));
assertEquals(15, parseInt('0xF_F', 16));
assertEquals(7, parseInt('7_7_7', 8));
assertEquals(1, parseInt('1_0_1_0', 2));
}
assertThrows('1_0_0_0_', SyntaxError);
assertThrows('1e_1', SyntaxError);
assertThrows('1e+_1', SyntaxError);
assertThrows('1_e+1', SyntaxError);
assertThrows('1__0', SyntaxError);
assertThrows('0x_1', SyntaxError);
assertThrows('0x1__1', SyntaxError);
assertThrows('0x1_', SyntaxError);
assertThrows('0b_0101', SyntaxError);
assertThrows('0b11_', SyntaxError);
assertThrows('0b1__1', SyntaxError);
assertThrows('0o777_', SyntaxError);
assertThrows('0o_777', SyntaxError);
assertThrows('0o7__77', SyntaxError);
assertThrows('0777_', SyntaxError);
assertThrows('07__77', SyntaxError);
assertThrows('07_7_7', SyntaxError);
assertThrows('09_1_3', SyntaxError);