All Downloads are FREE. Search and download functionalities are using the official Maven repository.

rhino1.7.7.testsrc.tests.ecma.LexicalConventions.7.7.4.js Maven / Gradle / Ivy

Go to download

Rhino is an open-source implementation of JavaScript written entirely in Java. It is typically embedded into Java applications to provide scripting to end users.

There is a newer version: 1.7.15
Show newest version
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

gTestfile = '7.7.4.js';

/**
   File Name:          7.7.4.js
   ECMA Section:       7.7.4 String Literals

   Description:        A string literal is zero or more characters enclosed in
   single or double quotes.  Each character may be
   represented by an escape sequence.


   Author:             [email protected]
   Date:               16 september 1997
*/

var SECTION = "7.7.4";
var VERSION = "ECMA_1";
startTest();
var TITLE   = "String Literals";

writeHeaderToLog( SECTION + " "+ TITLE);

// StringLiteral:: "" and ''

new TestCase( SECTION, "\"\"",     "",     "" );
new TestCase( SECTION, "\'\'",     "",      '' );

// DoubleStringCharacters:: DoubleStringCharacter :: EscapeSequence :: CharacterEscapeSequence
new TestCase( SECTION, "\\\"",        String.fromCharCode(0x0022),     "\"" );
new TestCase( SECTION, "\\\'",        String.fromCharCode(0x0027),     "\'" );
new TestCase( SECTION, "\\",         String.fromCharCode(0x005C),     "\\" );
new TestCase( SECTION, "\\b",        String.fromCharCode(0x0008),     "\b" );
new TestCase( SECTION, "\\f",        String.fromCharCode(0x000C),     "\f" );
new TestCase( SECTION, "\\n",        String.fromCharCode(0x000A),     "\n" );
new TestCase( SECTION, "\\r",        String.fromCharCode(0x000D),     "\r" );
new TestCase( SECTION, "\\t",        String.fromCharCode(0x0009),     "\t" );
new TestCase( SECTION, "\\v",        String.fromCharCode(0x000B),        "\v" );

// DoubleStringCharacters:DoubleStringCharacter::EscapeSequence::OctalEscapeSequence

new TestCase( SECTION, "\\00",      String.fromCharCode(0x0000),    "\00" );
new TestCase( SECTION, "\\01",      String.fromCharCode(0x0001),    "\01" );
new TestCase( SECTION, "\\02",      String.fromCharCode(0x0002),    "\02" );
new TestCase( SECTION, "\\03",      String.fromCharCode(0x0003),    "\03" );
new TestCase( SECTION, "\\04",      String.fromCharCode(0x0004),    "\04" );
new TestCase( SECTION, "\\05",      String.fromCharCode(0x0005),    "\05" );
new TestCase( SECTION, "\\06",      String.fromCharCode(0x0006),    "\06" );
new TestCase( SECTION, "\\07",      String.fromCharCode(0x0007),    "\07" );

new TestCase( SECTION, "\\010",      String.fromCharCode(0x0008),    "\010" );
new TestCase( SECTION, "\\011",      String.fromCharCode(0x0009),    "\011" );
new TestCase( SECTION, "\\012",      String.fromCharCode(0x000A),    "\012" );
new TestCase( SECTION, "\\013",      String.fromCharCode(0x000B),    "\013" );
new TestCase( SECTION, "\\014",      String.fromCharCode(0x000C),    "\014" );
new TestCase( SECTION, "\\015",      String.fromCharCode(0x000D),    "\015" );
new TestCase( SECTION, "\\016",      String.fromCharCode(0x000E),    "\016" );
new TestCase( SECTION, "\\017",      String.fromCharCode(0x000F),    "\017" );
new TestCase( SECTION, "\\020",      String.fromCharCode(0x0010),    "\020" );
new TestCase( SECTION, "\\042",      String.fromCharCode(0x0022),    "\042" );

new TestCase( SECTION, "\\0",      String.fromCharCode(0x0000),    "\0" );
new TestCase( SECTION, "\\1",      String.fromCharCode(0x0001),    "\1" );
new TestCase( SECTION, "\\2",      String.fromCharCode(0x0002),    "\2" );
new TestCase( SECTION, "\\3",      String.fromCharCode(0x0003),    "\3" );
new TestCase( SECTION, "\\4",      String.fromCharCode(0x0004),    "\4" );
new TestCase( SECTION, "\\5",      String.fromCharCode(0x0005),    "\5" );
new TestCase( SECTION, "\\6",      String.fromCharCode(0x0006),    "\6" );
new TestCase( SECTION, "\\7",      String.fromCharCode(0x0007),    "\7" );

new TestCase( SECTION, "\\10",      String.fromCharCode(0x0008),    "\10" );
new TestCase( SECTION, "\\11",      String.fromCharCode(0x0009),    "\11" );
new TestCase( SECTION, "\\12",      String.fromCharCode(0x000A),    "\12" );
new TestCase( SECTION, "\\13",      String.fromCharCode(0x000B),    "\13" );
new TestCase( SECTION, "\\14",      String.fromCharCode(0x000C),    "\14" );
new TestCase( SECTION, "\\15",      String.fromCharCode(0x000D),    "\15" );
new TestCase( SECTION, "\\16",      String.fromCharCode(0x000E),    "\16" );
new TestCase( SECTION, "\\17",      String.fromCharCode(0x000F),    "\17" );
new TestCase( SECTION, "\\20",      String.fromCharCode(0x0010),    "\20" );
new TestCase( SECTION, "\\42",      String.fromCharCode(0x0022),    "\42" );

new TestCase( SECTION, "\\000",      String.fromCharCode(0),        "\000" );
new TestCase( SECTION, "\\111",      String.fromCharCode(73),       "\111" );
new TestCase( SECTION, "\\222",      String.fromCharCode(146),      "\222" );
new TestCase( SECTION, "\\333",      String.fromCharCode(219),      "\333" );

//  following line commented out as it causes a compile time error
//    new TestCase( SECTION, "\\444",      "444",                         "\444" );

// DoubleStringCharacters:DoubleStringCharacter::EscapeSequence::HexEscapeSequence
/*
  new TestCase( SECTION, "\\x0",      String.fromCharCode(0),         "\x0" );
  new TestCase( SECTION, "\\x1",      String.fromCharCode(1),         "\x1" );
  new TestCase( SECTION, "\\x2",      String.fromCharCode(2),         "\x2" );
  new TestCase( SECTION, "\\x3",      String.fromCharCode(3),         "\x3" );
  new TestCase( SECTION, "\\x4",      String.fromCharCode(4),         "\x4" );
  new TestCase( SECTION, "\\x5",      String.fromCharCode(5),         "\x5" );
  new TestCase( SECTION, "\\x6",      String.fromCharCode(6),         "\x6" );
  new TestCase( SECTION, "\\x7",      String.fromCharCode(7),         "\x7" );
  new TestCase( SECTION, "\\x8",      String.fromCharCode(8),         "\x8" );
  new TestCase( SECTION, "\\x9",      String.fromCharCode(9),         "\x9" );
  new TestCase( SECTION, "\\xA",      String.fromCharCode(10),         "\xA" );
  new TestCase( SECTION, "\\xB",      String.fromCharCode(11),         "\xB" );
  new TestCase( SECTION, "\\xC",      String.fromCharCode(12),         "\xC" );
  new TestCase( SECTION, "\\xD",      String.fromCharCode(13),         "\xD" );
  new TestCase( SECTION, "\\xE",      String.fromCharCode(14),         "\xE" );
  new TestCase( SECTION, "\\xF",      String.fromCharCode(15),         "\xF" );

*/
new TestCase( SECTION, "\\xF0",      String.fromCharCode(240),         "\xF0" );
new TestCase( SECTION, "\\xE1",      String.fromCharCode(225),         "\xE1" );
new TestCase( SECTION, "\\xD2",      String.fromCharCode(210),         "\xD2" );
new TestCase( SECTION, "\\xC3",      String.fromCharCode(195),         "\xC3" );
new TestCase( SECTION, "\\xB4",      String.fromCharCode(180),         "\xB4" );
new TestCase( SECTION, "\\xA5",      String.fromCharCode(165),         "\xA5" );
new TestCase( SECTION, "\\x96",      String.fromCharCode(150),         "\x96" );
new TestCase( SECTION, "\\x87",      String.fromCharCode(135),         "\x87" );
new TestCase( SECTION, "\\x78",      String.fromCharCode(120),         "\x78" );
new TestCase( SECTION, "\\x69",      String.fromCharCode(105),         "\x69" );
new TestCase( SECTION, "\\x5A",      String.fromCharCode(90),         "\x5A" );
new TestCase( SECTION, "\\x4B",      String.fromCharCode(75),         "\x4B" );
new TestCase( SECTION, "\\x3C",      String.fromCharCode(60),         "\x3C" );
new TestCase( SECTION, "\\x2D",      String.fromCharCode(45),         "\x2D" );
new TestCase( SECTION, "\\x1E",      String.fromCharCode(30),         "\x1E" );
new TestCase( SECTION, "\\x0F",      String.fromCharCode(15),         "\x0F" );

// string literals only take up to two hext digits.  therefore, the third character in this string
// should be interpreted as a StringCharacter and not part of the HextEscapeSequence

new TestCase( SECTION, "\\xF0F",      String.fromCharCode(240)+"F",         "\xF0F" );
new TestCase( SECTION, "\\xE1E",      String.fromCharCode(225)+"E",         "\xE1E" );
new TestCase( SECTION, "\\xD2D",      String.fromCharCode(210)+"D",         "\xD2D" );
new TestCase( SECTION, "\\xC3C",      String.fromCharCode(195)+"C",         "\xC3C" );
new TestCase( SECTION, "\\xB4B",      String.fromCharCode(180)+"B",         "\xB4B" );
new TestCase( SECTION, "\\xA5A",      String.fromCharCode(165)+"A",         "\xA5A" );
new TestCase( SECTION, "\\x969",      String.fromCharCode(150)+"9",         "\x969" );
new TestCase( SECTION, "\\x878",      String.fromCharCode(135)+"8",         "\x878" );
new TestCase( SECTION, "\\x787",      String.fromCharCode(120)+"7",         "\x787" );
new TestCase( SECTION, "\\x696",      String.fromCharCode(105)+"6",         "\x696" );
new TestCase( SECTION, "\\x5A5",      String.fromCharCode(90)+"5",         "\x5A5" );
new TestCase( SECTION, "\\x4B4",      String.fromCharCode(75)+"4",         "\x4B4" );
new TestCase( SECTION, "\\x3C3",      String.fromCharCode(60)+"3",         "\x3C3" );
new TestCase( SECTION, "\\x2D2",      String.fromCharCode(45)+"2",         "\x2D2" );
new TestCase( SECTION, "\\x1E1",      String.fromCharCode(30)+"1",         "\x1E1" );
new TestCase( SECTION, "\\x0F0",      String.fromCharCode(15)+"0",         "\x0F0" );

// G is out of hex range

new TestCase( SECTION, "\\xG",        "xG",                                 "\xG" );
new TestCase( SECTION, "\\xCG",       "xCG",      				"\xCG" );

// DoubleStringCharacter::EscapeSequence::CharacterEscapeSequence::\ NonEscapeCharacter
new TestCase( SECTION, "\\a",    "a",        "\a" );
new TestCase( SECTION, "\\c",    "c",        "\c" );
new TestCase( SECTION, "\\d",    "d",        "\d" );
new TestCase( SECTION, "\\e",    "e",        "\e" );
new TestCase( SECTION, "\\g",    "g",        "\g" );
new TestCase( SECTION, "\\h",    "h",        "\h" );
new TestCase( SECTION, "\\i",    "i",        "\i" );
new TestCase( SECTION, "\\j",    "j",        "\j" );
new TestCase( SECTION, "\\k",    "k",        "\k" );
new TestCase( SECTION, "\\l",    "l",        "\l" );
new TestCase( SECTION, "\\m",    "m",        "\m" );
new TestCase( SECTION, "\\o",    "o",        "\o" );
new TestCase( SECTION, "\\p",    "p",        "\p" );
new TestCase( SECTION, "\\q",    "q",        "\q" );
new TestCase( SECTION, "\\s",    "s",        "\s" );
new TestCase( SECTION, "\\u",    "u",        "\u" );

new TestCase( SECTION, "\\w",    "w",        "\w" );
new TestCase( SECTION, "\\x",    "x",        "\x" );
new TestCase( SECTION, "\\y",    "y",        "\y" );
new TestCase( SECTION, "\\z",    "z",        "\z" );
new TestCase( SECTION, "\\9",    "9",        "\9" );

new TestCase( SECTION, "\\A",    "A",        "\A" );
new TestCase( SECTION, "\\B",    "B",        "\B" );
new TestCase( SECTION, "\\C",    "C",        "\C" );
new TestCase( SECTION, "\\D",    "D",        "\D" );
new TestCase( SECTION, "\\E",    "E",        "\E" );
new TestCase( SECTION, "\\F",    "F",        "\F" );
new TestCase( SECTION, "\\G",    "G",        "\G" );
new TestCase( SECTION, "\\H",    "H",        "\H" );
new TestCase( SECTION, "\\I",    "I",        "\I" );
new TestCase( SECTION, "\\J",    "J",        "\J" );
new TestCase( SECTION, "\\K",    "K",        "\K" );
new TestCase( SECTION, "\\L",    "L",        "\L" );
new TestCase( SECTION, "\\M",    "M",        "\M" );
new TestCase( SECTION, "\\N",    "N",        "\N" );
new TestCase( SECTION, "\\O",    "O",        "\O" );
new TestCase( SECTION, "\\P",    "P",        "\P" );
new TestCase( SECTION, "\\Q",    "Q",        "\Q" );
new TestCase( SECTION, "\\R",    "R",        "\R" );
new TestCase( SECTION, "\\S",    "S",        "\S" );
new TestCase( SECTION, "\\T",    "T",        "\T" );
new TestCase( SECTION, "\\U",    "U",        "\U" );
new TestCase( SECTION, "\\V",    "V",        "\V" );
new TestCase( SECTION, "\\W",    "W",        "\W" );
new TestCase( SECTION, "\\X",    "X",        "\X" );
new TestCase( SECTION, "\\Y",    "Y",        "\Y" );
new TestCase( SECTION, "\\Z",    "Z",        "\Z" );

// DoubleStringCharacter::EscapeSequence::UnicodeEscapeSequence

new TestCase( SECTION,  "\\u0020",  " ",        "\u0020" );
new TestCase( SECTION,  "\\u0021",  "!",        "\u0021" );
new TestCase( SECTION,  "\\u0022",  "\"",       "\u0022" );
new TestCase( SECTION,  "\\u0023",  "#",        "\u0023" );
new TestCase( SECTION,  "\\u0024",  "$",        "\u0024" );
new TestCase( SECTION,  "\\u0025",  "%",        "\u0025" );
new TestCase( SECTION,  "\\u0026",  "&",        "\u0026" );
new TestCase( SECTION,  "\\u0027",  "'",        "\u0027" );
new TestCase( SECTION,  "\\u0028",  "(",        "\u0028" );
new TestCase( SECTION,  "\\u0029",  ")",        "\u0029" );
new TestCase( SECTION,  "\\u002A",  "*",        "\u002A" );
new TestCase( SECTION,  "\\u002B",  "+",        "\u002B" );
new TestCase( SECTION,  "\\u002C",  ",",        "\u002C" );
new TestCase( SECTION,  "\\u002D",  "-",        "\u002D" );
new TestCase( SECTION,  "\\u002E",  ".",        "\u002E" );
new TestCase( SECTION,  "\\u002F",  "/",        "\u002F" );
new TestCase( SECTION,  "\\u0030",  "0",        "\u0030" );
new TestCase( SECTION,  "\\u0031",  "1",        "\u0031" );
new TestCase( SECTION,  "\\u0032",  "2",        "\u0032" );
new TestCase( SECTION,  "\\u0033",  "3",        "\u0033" );
new TestCase( SECTION,  "\\u0034",  "4",        "\u0034" );
new TestCase( SECTION,  "\\u0035",  "5",        "\u0035" );
new TestCase( SECTION,  "\\u0036",  "6",        "\u0036" );
new TestCase( SECTION,  "\\u0037",  "7",        "\u0037" );
new TestCase( SECTION,  "\\u0038",  "8",        "\u0038" );
new TestCase( SECTION,  "\\u0039",  "9",        "\u0039" );

test();




© 2015 - 2024 Weber Informatics LLC | Privacy Policy