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
|
/*
* Copyright (C) 2008 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.jack.opcodes.shr_long;
import com.android.jack.DxTestCase;
import com.android.jack.opcodes.shr_long.jm.T_shr_long_1;
import com.android.jack.opcodes.shr_long.jm.T_shr_long_3;
import com.android.jack.opcodes.shr_long.jm.T_shr_long_4;
import com.android.jack.opcodes.shr_long.jm.T_shr_long_5;
public class Test_shr_long extends DxTestCase {
/**
* @title Arguments = 40000000000l, 3
*/
public void testN1() {
T_shr_long_1 t = new T_shr_long_1();
assertEquals(5000000000l, t.run(40000000000l, 3));
}
/**
* @title Arguments = 40000000000l, 1
*/
public void testN2() {
T_shr_long_1 t = new T_shr_long_1();
assertEquals(20000000000l, t.run(40000000000l, 1));
}
/**
* @title Arguments = -40000000000l, 1
*/
public void testN3() {
T_shr_long_1 t = new T_shr_long_1();
assertEquals(-20000000000l, t.run(-40000000000l, 1));
}
/**
* @title Arguments = 1, -1
*/
public void testN4() {
T_shr_long_1 t = new T_shr_long_1();
assertEquals(0l, t.run(1l, -1));
}
/**
* @title Verify that shift distance is actually in range 0 to 64.
*/
public void testN5() {
T_shr_long_1 t = new T_shr_long_1();
assertEquals(32, t.run(65l, 65));
}
/**
* @title Verify that shift distance is actually in range 0 to 64.
*/
public void testN6() {
T_shr_long_3 t = new T_shr_long_3();
assertEquals(32, t.run(65l, 65));
}
/**
* @title Verify that shift distance is actually in range 0 to 64.
*/
public void testN7() {
T_shr_long_4 t = new T_shr_long_4();
assertEquals(32, t.run(65, 65));
}
/**
* @title Verify that shift distance is actually in range 0 to 64.
*/
public void testN8() {
T_shr_long_5 t = new T_shr_long_5();
assertEquals(32, t.run(65l, 65));
}
/**
* @title Arguments = 0, -1
*/
public void testB1() {
T_shr_long_1 t = new T_shr_long_1();
assertEquals(0l, t.run(0l, -1));
}
/**
* @title Arguments = 1, 0
*/
public void testB2() {
T_shr_long_1 t = new T_shr_long_1();
assertEquals(1l, t.run(1l, 0));
}
/**
* @title Arguments = Long.MAX_VALUE, 1
*/
public void testB3() {
T_shr_long_1 t = new T_shr_long_1();
assertEquals(0x3FFFFFFFFFFFFFFFl, t.run(Long.MAX_VALUE, 1));
}
/**
* @title Arguments = Long.MIN_VALUE, 1
*/
public void testB4() {
T_shr_long_1 t = new T_shr_long_1();
assertEquals(0xc000000000000000l, t.run(Long.MIN_VALUE, 1));
}
}
|