js/src/tests/ecma/Expressions/11.13.2-3.js

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

michael@0 1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
michael@0 2 /* This Source Code Form is subject to the terms of the Mozilla Public
michael@0 3 * License, v. 2.0. If a copy of the MPL was not distributed with this
michael@0 4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
michael@0 5
michael@0 6
michael@0 7 /**
michael@0 8 File Name: 11.13.2-4.js
michael@0 9 ECMA Section: 11.13.2 Compound Assignment: %=
michael@0 10 Description:
michael@0 11
michael@0 12 *= /= %= += -= <<= >>= >>>= &= ^= |=
michael@0 13
michael@0 14 11.13.2 Compound assignment ( op= )
michael@0 15
michael@0 16 The production AssignmentExpression :
michael@0 17 LeftHandSideExpression @ = AssignmentExpression, where @ represents one of
michael@0 18 the operators indicated above, is evaluated as follows:
michael@0 19
michael@0 20 1. Evaluate LeftHandSideExpression.
michael@0 21 2. Call GetValue(Result(1)).
michael@0 22 3. Evaluate AssignmentExpression.
michael@0 23 4. Call GetValue(Result(3)).
michael@0 24 5. Apply operator @ to Result(2) and Result(4).
michael@0 25 6. Call PutValue(Result(1), Result(5)).
michael@0 26 7. Return Result(5).
michael@0 27
michael@0 28 Author: christine@netscape.com
michael@0 29 Date: 12 november 1997
michael@0 30 */
michael@0 31 var SECTION = "11.13.2-3";
michael@0 32 var VERSION = "ECMA_1";
michael@0 33 startTest();
michael@0 34
michael@0 35 writeHeaderToLog( SECTION + " Compound Assignment: +=");
michael@0 36
michael@0 37 // If either operand is NaN, result is NaN
michael@0 38
michael@0 39 new TestCase( SECTION,
michael@0 40 "VAR1 = NaN; VAR2=1; VAR1 %= VAR2",
michael@0 41 Number.NaN,
michael@0 42 eval("VAR1 = Number.NaN; VAR2=1; VAR1 %= VAR2") );
michael@0 43
michael@0 44 new TestCase( SECTION,
michael@0 45 "VAR1 = NaN; VAR2=1; VAR1 %= VAR2; VAR1",
michael@0 46 Number.NaN,
michael@0 47 eval("VAR1 = Number.NaN; VAR2=1; VAR1 %= VAR2; VAR1") );
michael@0 48
michael@0 49 new TestCase( SECTION,
michael@0 50 "VAR1 = NaN; VAR2=0; VAR1 %= VAR2",
michael@0 51 Number.NaN,
michael@0 52 eval("VAR1 = Number.NaN; VAR2=0; VAR1 %= VAR2") );
michael@0 53
michael@0 54 new TestCase( SECTION,
michael@0 55 "VAR1 = NaN; VAR2=0; VAR1 %= VAR2; VAR1",
michael@0 56 Number.NaN,
michael@0 57 eval("VAR1 = Number.NaN; VAR2=0; VAR1 %= VAR2; VAR1") );
michael@0 58
michael@0 59 new TestCase( SECTION,
michael@0 60 "VAR1 = 0; VAR2=NaN; VAR1 %= VAR2",
michael@0 61 Number.NaN,
michael@0 62 eval("VAR1 = 0; VAR2=Number.NaN; VAR1 %= VAR2") );
michael@0 63
michael@0 64 new TestCase( SECTION,
michael@0 65 "VAR1 = 0; VAR2=NaN; VAR1 %= VAR2; VAR1",
michael@0 66 Number.NaN,
michael@0 67 eval("VAR1 = 0; VAR2=Number.NaN; VAR1 %= VAR2; VAR1") );
michael@0 68
michael@0 69 // if the dividend is infinity or the divisor is zero or both, the result is NaN
michael@0 70
michael@0 71 new TestCase( SECTION,
michael@0 72 "VAR1 = Infinity; VAR2= Infinity; VAR1 %= VAR2; VAR1",
michael@0 73 Number.NaN,
michael@0 74 eval("VAR1 = Number.POSITIVE_INFINITY; VAR2 = Number.POSITIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 75
michael@0 76 new TestCase( SECTION,
michael@0 77 "VAR1 = Infinity; VAR2= -Infinity; VAR1 %= VAR2; VAR1",
michael@0 78 Number.NaN,
michael@0 79 eval("VAR1 = Number.POSITIVE_INFINITY; VAR2 = Number.NEGATIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 80
michael@0 81 new TestCase( SECTION,
michael@0 82 "VAR1 =-Infinity; VAR2= Infinity; VAR1 %= VAR2; VAR1",
michael@0 83 Number.NaN,
michael@0 84 eval("VAR1 = Number.NEGATIVE_INFINITY; VAR2 = Number.POSITIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 85
michael@0 86 new TestCase( SECTION,
michael@0 87 "VAR1 =-Infinity; VAR2=-Infinity; VAR1 %= VAR2; VAR1",
michael@0 88 Number.NaN,
michael@0 89 eval("VAR1 = Number.NEGATIVE_INFINITY; VAR2 = Number.NEGATIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 90
michael@0 91 new TestCase( SECTION,
michael@0 92 "VAR1 = 0; VAR2= Infinity; VAR2 %= VAR1",
michael@0 93 Number.NaN,
michael@0 94 eval("VAR1 = 0; VAR2 = Number.POSITIVE_INFINITY; VAR2 %= VAR1; VAR2") );
michael@0 95
michael@0 96 new TestCase( SECTION,
michael@0 97 "VAR1 = -0; VAR2= Infinity; VAR2 %= VAR1",
michael@0 98 Number.NaN,
michael@0 99 eval("VAR1 = -0; VAR2 = Number.POSITIVE_INFINITY; VAR2 %= VAR1; VAR2") );
michael@0 100
michael@0 101 new TestCase( SECTION,
michael@0 102 "VAR1 = -0; VAR2= -Infinity; VAR2 %= VAR1",
michael@0 103 Number.NaN,
michael@0 104 eval("VAR1 = -0; VAR2 = Number.NEGATIVE_INFINITY; VAR2 %= VAR1; VAR2") );
michael@0 105
michael@0 106 new TestCase( SECTION,
michael@0 107 "VAR1 = 0; VAR2= -Infinity; VAR2 %= VAR1",
michael@0 108 Number.NaN,
michael@0 109 eval("VAR1 = 0; VAR2 = Number.NEGATIVE_INFINITY; VAR2 %= VAR1; VAR2") );
michael@0 110
michael@0 111 new TestCase( SECTION,
michael@0 112 "VAR1 = 1; VAR2= Infinity; VAR2 %= VAR1",
michael@0 113 Number.NaN,
michael@0 114 eval("VAR1 = 1; VAR2 = Number.POSITIVE_INFINITY; VAR2 %= VAR1; VAR2") );
michael@0 115
michael@0 116 new TestCase( SECTION,
michael@0 117 "VAR1 = -1; VAR2= Infinity; VAR2 %= VAR1",
michael@0 118 Number.NaN,
michael@0 119 eval("VAR1 = -1; VAR2 = Number.POSITIVE_INFINITY; VAR2 %= VAR1; VAR2") );
michael@0 120
michael@0 121 new TestCase( SECTION,
michael@0 122 "VAR1 = -1; VAR2= -Infinity; VAR2 %= VAR1",
michael@0 123 Number.NaN,
michael@0 124 eval("VAR1 = -1; VAR2 = Number.NEGATIVE_INFINITY; VAR2 %= VAR1; VAR2") );
michael@0 125
michael@0 126 new TestCase( SECTION,
michael@0 127 "VAR1 = 1; VAR2= -Infinity; VAR2 %= VAR1",
michael@0 128 Number.NaN,
michael@0 129 eval("VAR1 = 1; VAR2 = Number.NEGATIVE_INFINITY; VAR2 %= VAR1; VAR2") );
michael@0 130
michael@0 131 new TestCase( SECTION,
michael@0 132 "VAR1 = 0; VAR2= 0; VAR1 %= VAR2",
michael@0 133 Number.NaN,
michael@0 134 eval("VAR1 = 0; VAR2 = 0; VAR1 %= VAR2; VAR1") );
michael@0 135
michael@0 136 new TestCase( SECTION,
michael@0 137 "VAR1 = 0; VAR2= -0; VAR1 %= VAR2",
michael@0 138 Number.NaN,
michael@0 139 eval("VAR1 = 0; VAR2 = -0; VAR1 %= VAR2; VAR1") );
michael@0 140
michael@0 141 new TestCase( SECTION,
michael@0 142 "VAR1 = -0; VAR2= 0; VAR1 %= VAR2",
michael@0 143 Number.NaN,
michael@0 144 eval("VAR1 = -0; VAR2 = 0; VAR1 %= VAR2; VAR1") );
michael@0 145
michael@0 146 new TestCase( SECTION,
michael@0 147 "VAR1 = -0; VAR2= -0; VAR1 %= VAR2",
michael@0 148 Number.NaN,
michael@0 149 eval("VAR1 = -0; VAR2 = -0; VAR1 %= VAR2; VAR1") );
michael@0 150
michael@0 151 new TestCase( SECTION,
michael@0 152 "VAR1 = 1; VAR2= 0; VAR1 %= VAR2",
michael@0 153 Number.NaN,
michael@0 154 eval("VAR1 = 1; VAR2 = 0; VAR1 %= VAR2; VAR1") );
michael@0 155
michael@0 156 new TestCase( SECTION,
michael@0 157 "VAR1 = 1; VAR2= -0; VAR1 %= VAR2",
michael@0 158 Number.NaN,
michael@0 159 eval("VAR1 = 1; VAR2 = -0; VAR1 %= VAR2; VAR1") );
michael@0 160
michael@0 161 new TestCase( SECTION,
michael@0 162 "VAR1 = -1; VAR2= 0; VAR1 %= VAR2",
michael@0 163 Number.NaN,
michael@0 164 eval("VAR1 = -1; VAR2 = 0; VAR1 %= VAR2; VAR1") );
michael@0 165
michael@0 166 new TestCase( SECTION,
michael@0 167 "VAR1 = -1; VAR2= -0; VAR1 %= VAR2",
michael@0 168 Number.NaN,
michael@0 169 eval("VAR1 = -1; VAR2 = -0; VAR1 %= VAR2; VAR1") );
michael@0 170
michael@0 171 // if the dividend is finite and the divisor is an infinity, the result equals the dividend.
michael@0 172
michael@0 173 new TestCase( SECTION,
michael@0 174 "VAR1 = 0; VAR2= Infinity; VAR1 %= VAR2;VAR1",
michael@0 175 0,
michael@0 176 eval("VAR1 = 0; VAR2 = Number.POSITIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 177
michael@0 178 new TestCase( SECTION,
michael@0 179 "VAR1 = -0; VAR2= Infinity; VAR1 %= VAR2;VAR1",
michael@0 180 -0,
michael@0 181 eval("VAR1 = -0; VAR2 = Number.POSITIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 182
michael@0 183 new TestCase( SECTION,
michael@0 184 "VAR1 = -0; VAR2= -Infinity; VAR1 %= VAR2;VAR1",
michael@0 185 -0,
michael@0 186 eval("VAR1 = -0; VAR2 = Number.NEGATIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 187
michael@0 188 new TestCase( SECTION,
michael@0 189 "VAR1 = 0; VAR2= -Infinity; VAR1 %= VAR2;VAR1",
michael@0 190 0,
michael@0 191 eval("VAR1 = 0; VAR2 = Number.NEGATIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 192
michael@0 193 new TestCase( SECTION,
michael@0 194 "VAR1 = 1; VAR2= Infinity; VAR1 %= VAR2;VAR1",
michael@0 195 1,
michael@0 196 eval("VAR1 = 1; VAR2 = Number.POSITIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 197
michael@0 198 new TestCase( SECTION,
michael@0 199 "VAR1 = -1; VAR2= Infinity; VAR1 %= VAR2;VAR1",
michael@0 200 -1,
michael@0 201 eval("VAR1 = -1; VAR2 = Number.POSITIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 202
michael@0 203 new TestCase( SECTION,
michael@0 204 "VAR1 = -1; VAR2= -Infinity; VAR1 %= VAR2;VAR1",
michael@0 205 -1,
michael@0 206 eval("VAR1 = -1; VAR2 = Number.NEGATIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 207
michael@0 208 new TestCase( SECTION,
michael@0 209 "VAR1 = 1; VAR2= -Infinity; VAR1 %= VAR2;VAR1",
michael@0 210 1,
michael@0 211 eval("VAR1 = 1; VAR2 = Number.NEGATIVE_INFINITY; VAR1 %= VAR2; VAR1") );
michael@0 212
michael@0 213 // if the dividend is a zero and the divisor is finite, the result is the same as the dividend
michael@0 214
michael@0 215 new TestCase( SECTION,
michael@0 216 "VAR1 = 0; VAR2= 1; VAR1 %= VAR2; VAR1",
michael@0 217 0,
michael@0 218 eval("VAR1 = 0; VAR2 = 1; VAR1 %= VAR2; VAR1") );
michael@0 219
michael@0 220 new TestCase( SECTION,
michael@0 221 "VAR1 = -0; VAR2= 1; VAR1 %= VAR2; VAR1",
michael@0 222 -0,
michael@0 223 eval("VAR1 = -0; VAR2 = 1; VAR1 %= VAR2; VAR1") );
michael@0 224
michael@0 225 new TestCase( SECTION,
michael@0 226 "VAR1 = -0; VAR2= -1; VAR1 %= VAR2; VAR1",
michael@0 227 -0,
michael@0 228 eval("VAR1 = -0; VAR2 = -1; VAR1 %= VAR2; VAR1") );
michael@0 229
michael@0 230 new TestCase( SECTION,
michael@0 231 "VAR1 = 0; VAR2= -1; VAR1 %= VAR2; VAR1",
michael@0 232 0,
michael@0 233 eval("VAR1 = 0; VAR2 = -1; VAR1 %= VAR2; VAR1") );
michael@0 234
michael@0 235 // string cases
michael@0 236 new TestCase( SECTION,
michael@0 237 "VAR1 = 1000; VAR2 = '10', VAR1 %= VAR2; VAR1",
michael@0 238 0,
michael@0 239 eval("VAR1 = 1000; VAR2 = '10', VAR1 %= VAR2; VAR1") );
michael@0 240
michael@0 241 new TestCase( SECTION,
michael@0 242 "VAR1 = '1000'; VAR2 = 10, VAR1 %= VAR2; VAR1",
michael@0 243 0,
michael@0 244 eval("VAR1 = '1000'; VAR2 = 10, VAR1 %= VAR2; VAR1") );
michael@0 245 /*
michael@0 246 new TestCase( SECTION, "VAR1 = 10; VAR2 = '0XFF', VAR1 %= VAR2", 2550, eval("VAR1 = 10; VAR2 = '0XFF', VAR1 %= VAR2") );
michael@0 247 new TestCase( SECTION, "VAR1 = '0xFF'; VAR2 = 0xA, VAR1 %= VAR2", 2550, eval("VAR1 = '0XFF'; VAR2 = 0XA, VAR1 %= VAR2") );
michael@0 248
michael@0 249 new TestCase( SECTION, "VAR1 = '10'; VAR2 = '255', VAR1 %= VAR2", 2550, eval("VAR1 = '10'; VAR2 = '255', VAR1 %= VAR2") );
michael@0 250 new TestCase( SECTION, "VAR1 = '10'; VAR2 = '0XFF', VAR1 %= VAR2", 2550, eval("VAR1 = '10'; VAR2 = '0XFF', VAR1 %= VAR2") );
michael@0 251 new TestCase( SECTION, "VAR1 = '0xFF'; VAR2 = 0xA, VAR1 %= VAR2", 2550, eval("VAR1 = '0XFF'; VAR2 = 0XA, VAR1 %= VAR2") );
michael@0 252
michael@0 253 // boolean cases
michael@0 254 new TestCase( SECTION, "VAR1 = true; VAR2 = false; VAR1 %= VAR2", 0, eval("VAR1 = true; VAR2 = false; VAR1 %= VAR2") );
michael@0 255 new TestCase( SECTION, "VAR1 = true; VAR2 = true; VAR1 %= VAR2", 1, eval("VAR1 = true; VAR2 = true; VAR1 %= VAR2") );
michael@0 256
michael@0 257 // object cases
michael@0 258 new TestCase( SECTION, "VAR1 = new Boolean(true); VAR2 = 10; VAR1 %= VAR2;VAR1", 10, eval("VAR1 = new Boolean(true); VAR2 = 10; VAR1 %= VAR2; VAR1") );
michael@0 259 new TestCase( SECTION, "VAR1 = new Number(11); VAR2 = 10; VAR1 %= VAR2; VAR1", 110, eval("VAR1 = new Number(11); VAR2 = 10; VAR1 %= VAR2; VAR1") );
michael@0 260 new TestCase( SECTION, "VAR1 = new Number(11); VAR2 = new Number(10); VAR1 %= VAR2", 110, eval("VAR1 = new Number(11); VAR2 = new Number(10); VAR1 %= VAR2") );
michael@0 261 new TestCase( SECTION, "VAR1 = new String('15'); VAR2 = new String('0xF'); VAR1 %= VAR2", 255, eval("VAR1 = String('15'); VAR2 = new String('0xF'); VAR1 %= VAR2") );
michael@0 262
michael@0 263 */
michael@0 264
michael@0 265 test();
michael@0 266

mercurial