blob: 6d755046936d4e50c6311c8d885db2fb33029aea [file] [log] [blame]
Steve Blocka7e24c12009-10-30 11:49:00 +00001// Copyright 2008 the V8 project authors. All rights reserved.
2// Redistribution and use in source and binary forms, with or without
3// modification, are permitted provided that the following conditions are
4// met:
5//
6// * Redistributions of source code must retain the above copyright
7// notice, this list of conditions and the following disclaimer.
8// * Redistributions in binary form must reproduce the above
9// copyright notice, this list of conditions and the following
10// disclaimer in the documentation and/or other materials provided
11// with the distribution.
12// * Neither the name of Google Inc. nor the names of its
13// contributors may be used to endorse or promote products derived
14// from this software without specific prior written permission.
15//
16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28function assertClose(expected, actual) {
29 var delta = 0.00001;
30 if (Math.abs(expected - actual) > delta) {
Ben Murdoch589d6972011-11-30 16:04:58 +000031 print('Failure: Expected <' + actual + '> to be close to <' +
32 expected + '>');
Steve Blocka7e24c12009-10-30 11:49:00 +000033 }
34}
35
36assertEquals(1, Math.pow(NaN, 0));
37var pinf = Number.POSITIVE_INFINITY, ninf = Number.NEGATIVE_INFINITY;
38assertClose( Math.PI / 4, Math.atan2(pinf, pinf));
39assertClose(-Math.PI / 4, Math.atan2(ninf, pinf));
40assertClose( 3 * Math.PI / 4, Math.atan2(pinf, ninf));
41assertClose(-3 * Math.PI / 4, Math.atan2(ninf, ninf));