Fix to handle null input array, and remove check for NULL
git-svn-id: https://svn.apache.org/repos/asf/commons/proper/lang/trunk@881209 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
ac719ec4ab
commit
34b9c73a6d
|
@ -111,9 +111,11 @@ public class ObjectUtils {
|
||||||
* or <code>null</code> if there are no non-null values
|
* or <code>null</code> if there are no non-null values
|
||||||
*/
|
*/
|
||||||
public static <T> T firstNonNull(T... values) {
|
public static <T> T firstNonNull(T... values) {
|
||||||
for (T val : values) {
|
if (values != null) {
|
||||||
if (val != null && val != ObjectUtils.NULL) {
|
for (T val : values) {
|
||||||
return val;
|
if (val != null) {
|
||||||
|
return val;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -72,7 +72,7 @@ public class ObjectUtilsTest extends TestCase {
|
||||||
assertEquals(true, Modifier.isPublic(ObjectUtils.class.getModifiers()));
|
assertEquals(true, Modifier.isPublic(ObjectUtils.class.getModifiers()));
|
||||||
assertEquals(false, Modifier.isFinal(ObjectUtils.class.getModifiers()));
|
assertEquals(false, Modifier.isFinal(ObjectUtils.class.getModifiers()));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
//-----------------------------------------------------------------------
|
||||||
public void testIsNull() {
|
public void testIsNull() {
|
||||||
Object o = FOO;
|
Object o = FOO;
|
||||||
|
@ -81,6 +81,24 @@ public class ObjectUtilsTest extends TestCase {
|
||||||
assertSame("dflt was returned when o was not null", o, ObjectUtils.defaultIfNull(o, dflt));
|
assertSame("dflt was returned when o was not null", o, ObjectUtils.defaultIfNull(o, dflt));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testFirstNonNull() {
|
||||||
|
assertEquals(null, ObjectUtils.firstNonNull(null, null));
|
||||||
|
assertEquals("", ObjectUtils.firstNonNull(null, ""));
|
||||||
|
String firstNonNullGenerics = ObjectUtils.firstNonNull(null, null, "123", "456");
|
||||||
|
assertEquals("123", firstNonNullGenerics);
|
||||||
|
assertEquals("123", ObjectUtils.firstNonNull("123", null, "456", null));
|
||||||
|
assertEquals(null, ObjectUtils.firstNonNull());
|
||||||
|
assertSame(Boolean.TRUE, ObjectUtils.firstNonNull(Boolean.TRUE));
|
||||||
|
assertNull(ObjectUtils.firstNonNull());
|
||||||
|
assertNull(ObjectUtils.firstNonNull(null, null));
|
||||||
|
// assertSame("123", ObjectUtils.firstNonNull(null, ObjectUtils.NULL, "123", "456"));
|
||||||
|
// assertSame("456", ObjectUtils.firstNonNull(ObjectUtils.NULL, "456", "123", null));
|
||||||
|
// assertNull(ObjectUtils.firstNonNull(null, null, ObjectUtils.NULL));
|
||||||
|
assertNull(ObjectUtils.firstNonNull((Object) null));
|
||||||
|
assertNull(ObjectUtils.firstNonNull((Object[]) null));
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------
|
||||||
public void testEquals() {
|
public void testEquals() {
|
||||||
assertTrue("ObjectUtils.equals(null, null) returned false", ObjectUtils.equals(null, null));
|
assertTrue("ObjectUtils.equals(null, null) returned false", ObjectUtils.equals(null, null));
|
||||||
assertTrue("ObjectUtils.equals(\"foo\", null) returned true", !ObjectUtils.equals(FOO, null));
|
assertTrue("ObjectUtils.equals(\"foo\", null) returned true", !ObjectUtils.equals(FOO, null));
|
||||||
|
@ -217,18 +235,4 @@ public class ObjectUtilsTest extends TestCase {
|
||||||
assertNull( ObjectUtils.min((String)null, (String)null) );
|
assertNull( ObjectUtils.min((String)null, (String)null) );
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testFirstNonNull() {
|
|
||||||
assertEquals(null, ObjectUtils.firstNonNull(null, null));
|
|
||||||
assertEquals("", ObjectUtils.firstNonNull(null, ""));
|
|
||||||
assertEquals("123", ObjectUtils.firstNonNull(null, null, "123", "456"));
|
|
||||||
assertEquals("123", ObjectUtils.firstNonNull("123", null, "456", null));
|
|
||||||
assertEquals(null, ObjectUtils.firstNonNull());
|
|
||||||
assertSame(Boolean.TRUE, ObjectUtils.firstNonNull(Boolean.TRUE));
|
|
||||||
assertNull(ObjectUtils.firstNonNull());
|
|
||||||
assertNull(ObjectUtils.firstNonNull(null, null));
|
|
||||||
assertSame("123", ObjectUtils.firstNonNull(null, ObjectUtils.NULL, "123", "456"));
|
|
||||||
assertSame("456", ObjectUtils.firstNonNull(ObjectUtils.NULL, "456", "123", null));
|
|
||||||
assertNull(ObjectUtils.firstNonNull(null, null, ObjectUtils.NULL));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue