// Tags: JDK1.3 // Copyright (C) 2012 Pavel Tisnovsky <ptisnovs@redhat.com> // This file is part of Mauve. // Mauve is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation; either version 2, or (at your option) // any later version. // Mauve is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License // along with Mauve; see the file COPYING. If not, write to // the Free Software Foundation, 59 Temple Place - Suite 330, // Boston, MA 02111-1307, USA. package gnu.testlet.java.lang.Math; import gnu.testlet.Testlet; import gnu.testlet.TestHarness; /** * Test for a static method Math.acos() */ public class acos implements Testlet { public int getExpectedPass() { return 0; } public int getExpectedFail() { return 0; } public int getExpectedKnownFail() { return 0; } /** * Function (=static method) checked by this test. */ private static double testedFunction(double input) { return Math.acos(input); } /** * These values are used as arguments to compute acos using Math. */ private static double[] inputValues = { Double.NaN, Double.POSITIVE_INFINITY, Double.NEGATIVE_INFINITY, Double.MAX_VALUE, Double.MIN_VALUE, 0.0, 0.2, 0.4, 0.5, 0.6, 0.8, 1.0, 2.0, 1e10, 1e-10, -0.0, -0.2, -0.4, -0.5, -0.6, -0.8, -1.0, -2.0, -1e10, -1e-10, }; /** * These values are the expected results, obtained from the RI. */ private static double[] outputValues = { // output value input value Double.NaN, // NAN Double.NaN, // +Infinity Double.NaN, // -Infinity Double.NaN, // 1.7976931348623157E308 1.5707963267948966, // 4.9E-324 Math.PI/2.0, // 0.0 1.369438406004566, // 0.2 1.1592794807274085, // 0.4 1.0471975511965979, // 0.5 0.9272952180016123, // 0.6 0.6435011087932843, // 0.8 0.0, // 1.0 Double.NaN, // 2.0 Double.NaN, // 1.0E10 1.5707963266948965, // 1.0E-10 Math.PI/2.0, // -0.0 1.7721542475852274, // -0.2 1.9823131728623846, // -0.4 2.0943951023931957, // -0.5 2.214297435588181, // -0.6 2.498091544796509, // -0.8 Math.PI, // -1.0 Double.NaN, // -2.0 Double.NaN, // -1.0E10 1.5707963268948966, // -1.0E-1 }; /** * These values represent various NaN */ private static long[] NaNValues = { 0x7fff800000000000L, 0xffff800000000000L, 0x7fff812345abcdefL, 0xffff812345abcdefL, 0x7fff000000000001L, 0xffff000000000001L, 0x7fff7654321fedcbL, 0xffff7654321fedcbL }; /** * Test not NaN values. */ private void testInputValues(TestHarness harness) { double res; for (int i = 0; i < inputValues.length; ++i) { res = testedFunction(inputValues[i]); // exact equality if (Double.doubleToLongBits(res) != Double.doubleToLongBits(outputValues[i])) { harness.todo(Double.doubleToLongBits(res), Double.doubleToLongBits(outputValues[i])); } else { harness.check(Double.doubleToLongBits(res), Double.doubleToLongBits(outputValues[i])); } } } /** * Entry point to a test. */ public void test(TestHarness harness) { // Disabled until we can get it working on Mac. // testInputValues(harness); } /** * Run this on the RI to obtain the expected output values. */ public static void main(String[] argv) { for (int i = 0; i < inputValues.length; ++i) { double input = inputValues[i]; double output = testedFunction(inputValues[i]); System.out.println(" " + Double.toString(output) + ", // " + input); } } }