1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
|
// Test for method java.lang.Double.getClass().getDeclaredMethods()
// Copyright (C) 2012, 2013, 2014, 2015 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, Inc., 51 Franklin Street,
// Fifth Floor, Boston, MA 02110-1301 USA.
// Tags: JDK1.5
package gnu.testlet.java.lang.Double.classInfo;
import gnu.testlet.TestHarness;
import gnu.testlet.Testlet;
import java.lang.Double;
import java.util.Map;
import java.util.HashMap;
/**
* Test for method java.lang.Double.getClass().getDeclaredMethods()
*/
public class getDeclaredMethods implements Testlet
{
/**
* Runs the test using the specified harness.
*
* @param harness the test harness (<code>null</code> not permitted).
*/
public void test(TestHarness harness)
{
// map of declared methods which should exists
Map<String, String> testedDeclaredMethods = null;
// map of declared methods for (Open)JDK6
Map<String, String> testedDeclaredMethods_jdk6 = new HashMap<String, String>();
// map of declared methods for (Open)JDK7
Map<String, String> testedDeclaredMethods_jdk7 = new HashMap<String, String>();
// map for methods declared in (Open)JDK6
testedDeclaredMethods_jdk6.put("public boolean java.lang.Double.equals(java.lang.Object)", "equals");
testedDeclaredMethods_jdk6.put("public static java.lang.String java.lang.Double.toString(double)", "toString");
testedDeclaredMethods_jdk6.put("public java.lang.String java.lang.Double.toString()", "toString");
testedDeclaredMethods_jdk6.put("public int java.lang.Double.hashCode()", "hashCode");
testedDeclaredMethods_jdk6.put("public static long java.lang.Double.doubleToRawLongBits(double)", "doubleToRawLongBits");
testedDeclaredMethods_jdk6.put("public static long java.lang.Double.doubleToLongBits(double)", "doubleToLongBits");
testedDeclaredMethods_jdk6.put("public static double java.lang.Double.longBitsToDouble(long)", "longBitsToDouble");
testedDeclaredMethods_jdk6.put("public int java.lang.Double.compareTo(java.lang.Double)", "compareTo");
testedDeclaredMethods_jdk6.put("public int java.lang.Double.compareTo(java.lang.Object)", "compareTo");
testedDeclaredMethods_jdk6.put("public byte java.lang.Double.byteValue()", "byteValue");
testedDeclaredMethods_jdk6.put("public short java.lang.Double.shortValue()", "shortValue");
testedDeclaredMethods_jdk6.put("public int java.lang.Double.intValue()", "intValue");
testedDeclaredMethods_jdk6.put("public long java.lang.Double.longValue()", "longValue");
testedDeclaredMethods_jdk6.put("public float java.lang.Double.floatValue()", "floatValue");
testedDeclaredMethods_jdk6.put("public double java.lang.Double.doubleValue()", "doubleValue");
testedDeclaredMethods_jdk6.put("public static java.lang.Double java.lang.Double.valueOf(double)", "valueOf");
testedDeclaredMethods_jdk6.put("public static java.lang.Double java.lang.Double.valueOf(java.lang.String) throws java.lang.NumberFormatException", "valueOf");
testedDeclaredMethods_jdk6.put("public static java.lang.String java.lang.Double.toHexString(double)", "toHexString");
testedDeclaredMethods_jdk6.put("public static int java.lang.Double.compare(double,double)", "compare");
testedDeclaredMethods_jdk6.put("public static boolean java.lang.Double.isNaN(double)", "isNaN");
testedDeclaredMethods_jdk6.put("public boolean java.lang.Double.isNaN()", "isNaN");
testedDeclaredMethods_jdk6.put("public static boolean java.lang.Double.isInfinite(double)", "isInfinite");
testedDeclaredMethods_jdk6.put("public boolean java.lang.Double.isInfinite()", "isInfinite");
testedDeclaredMethods_jdk6.put("public static double java.lang.Double.parseDouble(java.lang.String) throws java.lang.NumberFormatException", "parseDouble");
// map for methods declared in (Open)JDK7
testedDeclaredMethods_jdk7.put("public boolean java.lang.Double.equals(java.lang.Object)", "equals");
testedDeclaredMethods_jdk7.put("public static java.lang.String java.lang.Double.toString(double)", "toString");
testedDeclaredMethods_jdk7.put("public java.lang.String java.lang.Double.toString()", "toString");
testedDeclaredMethods_jdk7.put("public int java.lang.Double.hashCode()", "hashCode");
testedDeclaredMethods_jdk7.put("public static long java.lang.Double.doubleToRawLongBits(double)", "doubleToRawLongBits");
testedDeclaredMethods_jdk7.put("public static long java.lang.Double.doubleToLongBits(double)", "doubleToLongBits");
testedDeclaredMethods_jdk7.put("public static double java.lang.Double.longBitsToDouble(long)", "longBitsToDouble");
testedDeclaredMethods_jdk7.put("public int java.lang.Double.compareTo(java.lang.Double)", "compareTo");
testedDeclaredMethods_jdk7.put("public int java.lang.Double.compareTo(java.lang.Object)", "compareTo");
testedDeclaredMethods_jdk7.put("public byte java.lang.Double.byteValue()", "byteValue");
testedDeclaredMethods_jdk7.put("public short java.lang.Double.shortValue()", "shortValue");
testedDeclaredMethods_jdk7.put("public int java.lang.Double.intValue()", "intValue");
testedDeclaredMethods_jdk7.put("public long java.lang.Double.longValue()", "longValue");
testedDeclaredMethods_jdk7.put("public float java.lang.Double.floatValue()", "floatValue");
testedDeclaredMethods_jdk7.put("public double java.lang.Double.doubleValue()", "doubleValue");
testedDeclaredMethods_jdk7.put("public static java.lang.Double java.lang.Double.valueOf(double)", "valueOf");
testedDeclaredMethods_jdk7.put("public static java.lang.Double java.lang.Double.valueOf(java.lang.String) throws java.lang.NumberFormatException", "valueOf");
testedDeclaredMethods_jdk7.put("public static java.lang.String java.lang.Double.toHexString(double)", "toHexString");
testedDeclaredMethods_jdk7.put("public static int java.lang.Double.compare(double,double)", "compare");
testedDeclaredMethods_jdk7.put("public static boolean java.lang.Double.isNaN(double)", "isNaN");
testedDeclaredMethods_jdk7.put("public boolean java.lang.Double.isNaN()", "isNaN");
testedDeclaredMethods_jdk7.put("public static boolean java.lang.Double.isInfinite(double)", "isInfinite");
testedDeclaredMethods_jdk7.put("public boolean java.lang.Double.isInfinite()", "isInfinite");
testedDeclaredMethods_jdk7.put("public static double java.lang.Double.parseDouble(java.lang.String) throws java.lang.NumberFormatException", "parseDouble");
// create instance of a class Double
final Object o = new Double(42.0);
// get a runtime class of an object "o"
final Class c = o.getClass();
// get the right map containing method signatures
testedDeclaredMethods = getJavaVersion() < 7 ? testedDeclaredMethods_jdk6 : testedDeclaredMethods_jdk7;
// get all declared methods for this class
java.lang.reflect.Method[] declaredMethods = c.getDeclaredMethods();
// expected number of declared methods
final int expectedNumberOfDeclaredMethods = testedDeclaredMethods.size();
// basic check for a number of declared methods
harness.check(declaredMethods.length, expectedNumberOfDeclaredMethods);
// check if all declared methods exist
for (java.lang.reflect.Method declaredMethod : declaredMethods) {
// method name should consists of package name + class name
String methodName = declaredMethod.getName();
// modifiers + package + method name + parameter types
String methodString = declaredMethod.toString().replaceAll(" native ", " ");
harness.check(testedDeclaredMethods.containsKey(methodString));
harness.check(testedDeclaredMethods.get(methodString), methodName);
}
}
/**
* Returns version of Java. The input could have the following form: "1.7.0_06"
* and we are interested only in "7" in this case.
*
* @return Java version
*/
protected int getJavaVersion() {
String javaVersionStr = System.getProperty("java.version");
String[] parts = javaVersionStr.split("\\.");
return Integer.parseInt(parts[1]);
}
}
|