mirror of
https://github.com/corda/corda.git
synced 2024-12-31 18:27:05 +00:00
9411c223af
commit fabf4dd0cca19118c59c925f572a655d1d9c4092
Author: Joel Dice <joel.dice@gmail.com>
Date: Sun Jul 9 17:36:06 2017 -0600
reserve a little more stack space for worst-case lambda expressions
commit 24b95016dd6f62fa4a82312310fcb5c55cc22f93
Author: Joel Dice <joel.dice@gmail.com>
Date: Sun Jul 9 17:33:39 2017 -0600
support constructor references
commit a329416f4f37840d2a5d7976874585413cd4c6af
Author: Joel Dice <joel.dice@gmail.com>
Date: Sun Jul 9 17:11:19 2017 -0600
normalize class name in Classes.forName
This fixes a Tomcat classloading issue when using the OpenJDK class library.
commit ecafdf40baf2f3cde4835620e9af4380b1081fe7
Author: Joel Dice <joel.dice@gmail.com>
Date: Sun Jul 9 16:58:04 2017 -0600
fix some lambda bugs
commit 552dfd779baf077cc6445b4042588e4b6e34f3d2
Merge: 63dda56 aa2f25d
Author: Joel Dice <joel.dice@gmail.com>
Date: Sat Jul 8 10:57:59 2017 -0600
Merge remote-tracking branch 'corda/chrisr3-invoking-extension'
commit 63dda560f8648a793bdb609879076ab729b17e19
Merge: 3ec983d e589f10
Author: Joel Dice <joel.dice@gmail.com>
Date: Sat Jul 8 10:54:53 2017 -0600
Merge pull request #538 from dicej/master
avoid definePackage infinite recursion with OpenJDK class library
commit aa2f25da404b2fc168a672392df939b52ea250ab
Author: Chris Rankin <chris.rankin@r3.com>
Date: Mon Jul 3 17:26:41 2017 +0100
Add support for "invokevirtual" and "invokeinterface".
The "invokeinterface" support seems to be broken for lambdas that require native types to be boxed/unboxed.
commit e589f105741ea36d07bba1e300c7ed69c33a22d1
Author: Joel Dice <joel.dice@gmail.com>
Date: Sun Jul 2 19:43:36 2017 -0600
avoid definePackage infinite recursion with OpenJDK class library
commit 3ec983dd82e01b36fb96411df345a54119a68181
Merge: 6f6bdd7 78881d4
Author: Joel Dice <joel.dice@gmail.com>
Date: Tue Jun 13 09:50:49 2017 -0600
Merge pull request #534 from lwahlmeier/fileGetParentFile
fixed File.getParent when getting parent returns root
commit 78881d427cd474c14f5ce94484f5253de564074b
Author: Luke Wahlmeier <lwahlmeier@gmail.com>
Date: Tue May 30 13:42:56 2017 -0600
fixed File.getParent when getting parent returns root
commit 6f6bdd7d5c171e0c4c807d0a4f3aa676461307de
Merge: 8b694f9 b22343e
Author: Joel Dice <joel.dice@gmail.com>
Date: Mon May 22 12:58:09 2017 -0600
Merge pull request #529 from mikehearn/proguard-fixes
Some fixes to the ProGuard files
commit 8b694f961496f2d47a377254f61153b0338335fd
Merge: dfae414 61c82e1
Author: Joel Dice <joel.dice@gmail.com>
Date: Mon May 22 12:57:54 2017 -0600
Merge pull request #531 from mikehearn/fileinputstream-compat
FileInputStream has wrapped some more native methods
commit dfae414da8da57049076c16c43472cc32bdeb07c
Merge: 16dd804 d7a6f68
Author: Joel Dice <joel.dice@gmail.com>
Date: Mon May 22 12:57:38 2017 -0600
Merge pull request #532 from mikehearn/use-symlinks
Symlink OpenJDK files rather than hardlink
commit d7a6f68235b2d42c03aba36f1bb48d173adb4fa6
Author: Mike Hearn <mike@plan99.net>
Date: Sun May 14 21:42:06 2017 +0200
Symlink OpenJDK files rather than hardlink
commit 61c82e1070d857bcdc7a4f086d13836d9608da00
Author: Mike Hearn <mike@plan99.net>
Date: Sun May 14 21:40:52 2017 +0200
FileInputStream has wrapped some more native methods in recent OpenJDK releases
commit b22343eb6731f1df2631635e2fcf9d51817273fe
Author: Mike Hearn <mike@plan99.net>
Date: Sun May 14 21:38:09 2017 +0200
Some fixes to the ProGuard files
commit 16dd804f392168497fa17ab682978f938e291bfb
Merge: e2d3270 19deadd
Author: Joel Dice <joel.dice@gmail.com>
Date: Wed Mar 22 16:00:30 2017 -0600
Merge pull request #526 from MaartenR/arrays-binsearch
Added integer array binary search methods to Arrays class
commit e2d3270fe8e92203b6107b95f862ff5bd245c37a
Merge: dee99d6 545b9c8
Author: Joel Dice <joel.dice@gmail.com>
Date: Wed Mar 22 16:00:20 2017 -0600
Merge pull request #527 from MaartenR/integer-nolz
Added numberOfLeadingZeros method to Integer class
commit 545b9c8732a6ea026285b1edf976a79eb541ef2e
Author: Maarten Raaphorst <mwraaphorst@gmail.com>
Date: Tue Mar 14 11:23:36 2017 +0100
Tested more negative numbers
commit b45bcf09535daef99ed31451ae55db8bec83164c
Author: Maarten Raaphorst <mwraaphorst@gmail.com>
Date: Tue Mar 14 10:47:27 2017 +0100
Added unit test for numberOfLeadingZeros method of the Integer class
commit 19deadd36bbfc02a8c13e6d91963e41f5125057f
Author: Maarten Raaphorst <mwraaphorst@gmail.com>
Date: Mon Mar 13 12:19:17 2017 +0100
Fixed mistake with end index being exclusive
commit 7271c0b7077ae3bef473e036aa0f0298a9eb0601
Author: Maarten Raaphorst <mwraaphorst@gmail.com>
Date: Fri Mar 10 11:17:13 2017 +0100
Added numberOfLeadingZeros method to Integer class
commit 023bb69acd071348f29cd43ff954d3dcf2856c7c
Author: Maarten Raaphorst <mwraaphorst@gmail.com>
Date: Thu Mar 9 13:43:03 2017 +0100
Added integer array binary search methods to Arrays class
commit dee99d6dd60b743a870d1a2c58183649c8a6449c
Merge: f7a651d
6c90953
Author: Joel Dice <joel.dice@gmail.com>
Date: Wed Mar 1 08:39:32 2017 -0700
Merge pull request #525 from MaartenR/master
Added functionality to HttpURLConnection for obtaining content length
commit 6c90953745be5451ac9a028639f94e3fcc43d7f3
Author: Maarten Raaphorst <raaphorst@serviceplanet.nl>
Date: Wed Mar 1 14:19:51 2017 +0100
Made http headers case insensitive
commit 2c3a82d2b387251a8932ddb6575e718c2c1785a7
Author: Maarten Raaphorst <mwraaphorst@gmail.com>
Date: Fri Feb 3 05:42:56 2017 -0800
Added functionality to HttpURLConnection for obtaining content length
207 lines
5.3 KiB
Java
207 lines
5.3 KiB
Java
import java.util.Arrays;
|
|
|
|
public class ArraysTest {
|
|
private static void expect(boolean v) {
|
|
if (! v) throw new RuntimeException();
|
|
}
|
|
|
|
private static <T extends Comparable<T>> void expectSorted(T[] array) {
|
|
for (int i = 1; i < array.length; ++i) {
|
|
expect(array[i - 1].compareTo(array[i]) <= 0);
|
|
}
|
|
}
|
|
|
|
private static int pseudoRandom(int seed) {
|
|
return 3170425 * seed + 132102;
|
|
}
|
|
|
|
private static <T extends Comparable<T>> int shuffle(T[] array, int seed) {
|
|
for (int i = array.length; i > 1; --i) {
|
|
int i2 = (seed < 0 ? -seed : seed) % i;
|
|
T value = array[i - 1];
|
|
array[i - 1] = array[i2];
|
|
array[i2] = value;
|
|
seed = pseudoRandom(seed);
|
|
}
|
|
return seed;
|
|
}
|
|
|
|
public static void testSort() {
|
|
Integer[] array = new Integer[64];
|
|
for (int i = 0; i < array.length; ++i) {
|
|
array[i] = Integer.valueOf(i + 1);
|
|
}
|
|
;
|
|
int random = 12345;
|
|
for (int i = 0; i < 32; ++i) {
|
|
random = shuffle(array, random);
|
|
Arrays.sort(array);
|
|
expectSorted(array);
|
|
}
|
|
}
|
|
|
|
public static void testBinarySearch() {
|
|
int[] a = new int[]{ 1, 5, 7, 8, 10, 13, 17, 18, 21, 26 };
|
|
|
|
int i = Arrays.binarySearch(a, 5);
|
|
expect(i == 1);
|
|
i = Arrays.binarySearch(a, 17);
|
|
expect(i == 6);
|
|
i = Arrays.binarySearch(a, 6);
|
|
expect(i == -3);
|
|
i = Arrays.binarySearch(a, 1, 4, 8);
|
|
expect(i == 3);
|
|
i = Arrays.binarySearch(a, 1, 4, 10);
|
|
expect(i == -5);
|
|
|
|
Exception exception = null;
|
|
try {
|
|
Arrays.binarySearch(a, -1, a.length, 4);
|
|
} catch (ArrayIndexOutOfBoundsException e) {
|
|
exception = e;
|
|
}
|
|
expect(exception != null);
|
|
|
|
exception = null;
|
|
try {
|
|
Arrays.binarySearch(a, 0, a.length + 1, 4);
|
|
} catch (ArrayIndexOutOfBoundsException e) {
|
|
exception = e;
|
|
}
|
|
expect(exception != null);
|
|
}
|
|
|
|
public static void main(String[] args) {
|
|
{ int[] array = new int[0];
|
|
Exception exception = null;
|
|
try {
|
|
int x = array[0];
|
|
} catch (ArrayIndexOutOfBoundsException e) {
|
|
exception = e;
|
|
}
|
|
|
|
expect(exception != null);
|
|
}
|
|
|
|
{ int[] array = new int[0];
|
|
Exception exception = null;
|
|
try {
|
|
int x = array[-1];
|
|
} catch (ArrayIndexOutOfBoundsException e) {
|
|
exception = e;
|
|
}
|
|
|
|
expect(exception != null);
|
|
}
|
|
|
|
{ int[] array = new int[3];
|
|
int i = 0;
|
|
array[i++] = 1;
|
|
array[i++] = 2;
|
|
array[i++] = 3;
|
|
|
|
expect(array[--i] == 3);
|
|
expect(array[--i] == 2);
|
|
expect(array[--i] == 1);
|
|
}
|
|
|
|
{ Object[][] array = new Object[1][1];
|
|
expect(array.length == 1);
|
|
expect(array[0].length == 1);
|
|
}
|
|
|
|
{ Object[][] array = new Object[2][3];
|
|
expect(array.length == 2);
|
|
expect(array[0].length == 3);
|
|
}
|
|
|
|
{ int j = 0;
|
|
byte[] decodeTable = new byte[256];
|
|
for (int i = 'A'; i <= 'Z'; ++i) decodeTable[i] = (byte) j++;
|
|
for (int i = 'a'; i <= 'z'; ++i) decodeTable[i] = (byte) j++;
|
|
for (int i = '0'; i <= '9'; ++i) decodeTable[i] = (byte) j++;
|
|
decodeTable['+'] = (byte) j++;
|
|
decodeTable['/'] = (byte) j++;
|
|
decodeTable['='] = 0;
|
|
|
|
expect(decodeTable['a'] != 0);
|
|
}
|
|
|
|
{ boolean p = true;
|
|
int[] array = new int[] { 1, 2 };
|
|
expect(array[0] == array[p ? 0 : 1]);
|
|
p = false;
|
|
expect(array[1] == array[p ? 0 : 1]);
|
|
}
|
|
|
|
{ int[] array = new int[1024];
|
|
array[1023] = -1;
|
|
expect(array[1023] == -1);
|
|
expect(array[1022] == 0);
|
|
}
|
|
|
|
{ Integer[] array = (Integer[])
|
|
java.lang.reflect.Array.newInstance(Integer.class, 1);
|
|
array[0] = Integer.valueOf(42);
|
|
expect(array[0].intValue() == 42);
|
|
}
|
|
|
|
{ Object[] a = new Object[3];
|
|
Object[] b = new Object[3];
|
|
|
|
expect(Arrays.equals(a, b));
|
|
a[0] = new Object();
|
|
expect(! Arrays.equals(a, b));
|
|
expect(! Arrays.equals(b, new Object[4]));
|
|
expect(! Arrays.equals(a, null));
|
|
expect(! Arrays.equals(null, b));
|
|
expect(Arrays.equals((Object[])null, (Object[])null));
|
|
b[0] = a[0];
|
|
expect(Arrays.equals(a, b));
|
|
|
|
Arrays.hashCode(a);
|
|
Arrays.hashCode((Object[])null);
|
|
}
|
|
|
|
{ String[] list = new String[] { "Hello", "World", "!" };
|
|
Object[] result = Arrays.copyOf(list, 2, Object[].class);
|
|
expect(list[1] == result[1]);
|
|
expect(result.length == 2);
|
|
expect(result.getClass().getComponentType() == Object.class);
|
|
}
|
|
|
|
{ Object[] a = new Object[3];
|
|
Object[] b = new Object[3];
|
|
|
|
expect(Arrays.deepEquals(a, b));
|
|
|
|
a[0] = new Object();
|
|
expect(! Arrays.deepEquals(a, b));
|
|
expect(! Arrays.deepEquals(b, new Object[4]));
|
|
expect(! Arrays.deepEquals(a, null));
|
|
expect(! Arrays.deepEquals(null, b));
|
|
expect(Arrays.deepEquals((Object[])null, (Object[])null));
|
|
|
|
b[0] = a[0];
|
|
expect(Arrays.deepEquals(a, b));
|
|
|
|
a[0] = new Object[] {1};
|
|
expect(! Arrays.deepEquals(a, b));
|
|
b[0] = new Object[] {1};
|
|
expect(Arrays.deepEquals(a, b));
|
|
((Object[])a[0])[0] = (Long)1L;
|
|
expect(! Arrays.deepEquals(a, b));
|
|
a[0] = new Integer[] {1};
|
|
expect(Arrays.deepEquals(a, b));
|
|
|
|
a[0] = new int[] {1};
|
|
expect(! Arrays.deepEquals(a, b));
|
|
b[0] = new int[] {1};
|
|
expect(Arrays.deepEquals(a, b));
|
|
}
|
|
|
|
testSort();
|
|
testBinarySearch();
|
|
}
|
|
}
|