2 * Back 2 Browser Bytecode Translator
3 * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, version 2 of the License.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. Look for COPYING file in the top folder.
16 * If not, see http://opensource.org/licenses/GPL-2.0.
18 package org.apidesign.bck2brwsr.tck;
20 import java.lang.reflect.Array;
21 import org.apidesign.bck2brwsr.vmtest.Compare;
22 import org.apidesign.bck2brwsr.vmtest.VMTest;
23 import org.testng.annotations.Factory;
27 * @author Jaroslav Tulach <jtulach@netbeans.org>
29 public class ReflectionArrayTest {
30 @Compare public int lengthOfStringArray() {
31 String[] arr = (String[]) Array.newInstance(String.class, 10);
35 @Compare public int reflectiveLengthOfStringArray() {
36 Object arr = Array.newInstance(String.class, 10);
37 return Array.getLength(arr);
40 @Compare public int reflectiveLengthOneNonArray() {
41 Object arr = "non-array";
42 return Array.getLength(arr);
45 @Compare public String compTypeOfStringArray() {
46 String[] arr = (String[]) Array.newInstance(String.class, 10);
47 return arr.getClass().getComponentType().getName();
50 @Compare public Object negativeArrayExcp() {
51 return Array.newInstance(String.class, -5);
54 @Compare public int lengthOfIntArray() {
55 int[] arr = (int[]) Array.newInstance(Integer.TYPE, 10);
59 @Compare public int reflectiveLengthOfIntArray() {
60 Object arr = Array.newInstance(Integer.TYPE, 10);
61 return Array.getLength(arr);
64 @Compare public String compTypeOfIntArray() {
65 int[] arr = (int[]) Array.newInstance(int.class, 10);
66 return arr.getClass().getComponentType().getName();
69 @Compare public Object intNegativeArrayExcp() {
70 return Array.newInstance(int.class, -5);
73 @Compare public Integer verifyAutobox() {
74 int[] arr = (int[]) Array.newInstance(int.class, 5);
75 return (Integer) Array.get(arr, 0);
77 @Compare public int verifyInt() {
78 int[] arr = (int[]) Array.newInstance(int.class, 5);
79 return Array.getInt(arr, 0);
81 @Compare public long verifyConvertToLong() {
82 int[] arr = (int[]) Array.newInstance(int.class, 5);
83 return Array.getLong(arr, 0);
86 @Compare public Object verifySetIntToObject() {
87 Object[] arr = (Object[]) Array.newInstance(Object.class, 5);
88 Array.setInt(arr, 0, 10);
89 return Array.get(arr, 0);
91 @Compare public long verifySetShort() {
92 int[] arr = (int[]) Array.newInstance(int.class, 5);
93 Array.setShort(arr, 0, (short)10);
94 return Array.getLong(arr, 0);
96 @Compare public long verifyCantSetLong() {
97 int[] arr = (int[]) Array.newInstance(int.class, 5);
98 Array.setLong(arr, 0, 10);
99 return Array.getLong(arr, 0);
102 @Compare public double verifyConvertToDouble() {
103 int[] arr = (int[]) Array.newInstance(int.class, 5);
104 return Array.getDouble(arr, 0);
107 @Compare public int multiIntArray() {
108 int[][][] arr = (int[][][]) Array.newInstance(int.class, 3, 3, 3);
109 return arr[0][1][2] + 5 + arr[2][2][0];
112 @Compare public String multiIntArrayCompType() {
113 return Array.newInstance(int.class, 3, 3, 3).getClass().getName();
118 public static Object[] create() {
119 return VMTest.create(ReflectionArrayTest.class);