1 /* 2 * Copyright (C) 2008 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package dot.junit.opcodes.cmpl_float; 18 19 import dot.junit.DxTestCase; 20 import dot.junit.DxUtil; 21 import dot.junit.opcodes.cmpl_float.d.T_cmpl_float_6; 22 import dot.junit.opcodes.cmpl_float.d.T_cmpl_float_1; 23 24 public class Test_cmpl_float extends DxTestCase { 25 /** 26 * @title Arguments = 3.14f, 2.7f 27 */ 28 public void testN1() { 29 T_cmpl_float_1 t = new T_cmpl_float_1(); 30 assertEquals(1, t.run(3.14f, 2.7f)); 31 } 32 33 /** 34 * @title Arguments = -3.14f, 2.7f 35 */ 36 public void testN2() { 37 T_cmpl_float_1 t = new T_cmpl_float_1(); 38 assertEquals(-1, t.run(-3.14f, 2.7f)); 39 } 40 41 /** 42 * @title Arguments = 3.14, 3.14 43 */ 44 public void testN3() { 45 T_cmpl_float_1 t = new T_cmpl_float_1(); 46 assertEquals(0, t.run(3.14f, 3.14f)); 47 } 48 49 /** 50 * @title Arguments = Float.NaN, Float.MAX_VALUE 51 */ 52 public void testB1() { 53 T_cmpl_float_1 t = new T_cmpl_float_1(); 54 assertEquals(-1, t.run(Float.NaN, Float.MAX_VALUE)); 55 } 56 57 /** 58 * @title Arguments = +0, -0 59 */ 60 public void testB2() { 61 T_cmpl_float_1 t = new T_cmpl_float_1(); 62 assertEquals(0, t.run(+0f, -0f)); 63 } 64 65 /** 66 * @title Arguments = Float.NEGATIVE_INFINITY, Float.MIN_VALUE 67 */ 68 public void testB3() { 69 T_cmpl_float_1 t = new T_cmpl_float_1(); 70 assertEquals(-1, t.run(Float.NEGATIVE_INFINITY, Float.MIN_VALUE)); 71 } 72 73 /** 74 * @title Arguments = Float.POSITIVE_INFINITY, Float.MAX_VALUE 75 */ 76 public void testB4() { 77 T_cmpl_float_1 t = new T_cmpl_float_1(); 78 assertEquals(1, t.run(Float.POSITIVE_INFINITY, Float.MAX_VALUE)); 79 } 80 81 /** 82 * @title Arguments = Float.POSITIVE_INFINITY, 83 * Float.NEGATIVE_INFINITY 84 */ 85 public void testB5() { 86 T_cmpl_float_1 t = new T_cmpl_float_1(); 87 assertEquals(1, t.run(Float.POSITIVE_INFINITY, Float.NEGATIVE_INFINITY)); 88 } 89 90 91 92 /** 93 * @constraint B1 94 * @title types of arguments - float, double 95 */ 96 public void testVFE1() { 97 try { 98 Class.forName("dot.junit.opcodes.cmpl_float.d.T_cmpl_float_2"); 99 fail("expected a verification exception"); 100 } catch (Throwable t) { 101 DxUtil.checkVerifyException(t); 102 } 103 } 104 105 /** 106 * @constraint B1 107 * @title types of arguments - long, float 108 */ 109 public void testVFE2() { 110 try { 111 Class.forName("dot.junit.opcodes.cmpl_float.d.T_cmpl_float_3"); 112 fail("expected a verification exception"); 113 } catch (Throwable t) { 114 DxUtil.checkVerifyException(t); 115 } 116 } 117 118 /** 119 * @constraint B1 120 * @title types of arguments - reference, float 121 */ 122 public void testVFE3() { 123 try { 124 Class.forName("dot.junit.opcodes.cmpl_float.d.T_cmpl_float_4"); 125 fail("expected a verification exception"); 126 } catch (Throwable t) { 127 DxUtil.checkVerifyException(t); 128 } 129 } 130 131 /** 132 * @constraint A23 133 * @title number of registers 134 */ 135 public void testVFE4() { 136 try { 137 Class.forName("dot.junit.opcodes.cmpl_float.d.T_cmpl_float_5"); 138 fail("expected a verification exception"); 139 } catch (Throwable t) { 140 DxUtil.checkVerifyException(t); 141 } 142 } 143 144 /** 145 * @constraint B1 146 * @title Types of arguments - int, float. The verifier checks that ints 147 * and floats are not used interchangeably. 148 */ 149 public void testVFE5() { 150 try { 151 Class.forName("dot.junit.opcodes.cmpl_float.d.T_cmpl_float_6"); 152 fail("expected a verification exception"); 153 } catch (Throwable t) { 154 DxUtil.checkVerifyException(t); 155 } 156 } 157 158 } 159