mirror of
https://gitee.com/dromara/hutool.git
synced 2025-10-24 09:49:18 +08:00
BooleanUtil的andOfWrap和orOfWrap()忽略null
This commit is contained in:
@@ -3,9 +3,10 @@
|
||||
|
||||
-------------------------------------------------------------------------------------------------------------
|
||||
|
||||
# 5.8.7.M1 (2022-09-07)
|
||||
# 5.8.7.M1 (2022-09-13)
|
||||
|
||||
### 🐣新特性
|
||||
* 【core 】 BooleanUtil的andOfWrap和orOfWrap()忽略null(issue#2599@Github)
|
||||
### 🐞Bug修复
|
||||
|
||||
-------------------------------------------------------------------------------------------------------------
|
||||
|
@@ -356,8 +356,13 @@ public class BooleanUtil {
|
||||
if (ArrayUtil.isEmpty(array)) {
|
||||
throw new IllegalArgumentException("The Array must not be empty !");
|
||||
}
|
||||
final boolean[] primitive = Convert.convert(boolean[].class, array);
|
||||
return and(primitive);
|
||||
|
||||
for (final Boolean b : array) {
|
||||
if(isFalse(b)){
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -407,8 +412,13 @@ public class BooleanUtil {
|
||||
if (ArrayUtil.isEmpty(array)) {
|
||||
throw new IllegalArgumentException("The Array must not be empty !");
|
||||
}
|
||||
final boolean[] primitive = Convert.convert(boolean[].class, array);
|
||||
return or(primitive);
|
||||
|
||||
for (final Boolean b : array) {
|
||||
if(isTrue(b)){
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@@ -1283,7 +1283,8 @@ public class PrimitiveArrayUtil {
|
||||
}
|
||||
|
||||
/**
|
||||
* 包装类数组转为原始类型数组
|
||||
* 包装类数组转为原始类型数组<br>
|
||||
* {@code null} 按照 {@code false} 对待
|
||||
*
|
||||
* @param values 包装类型数组
|
||||
* @return 原始类型数组
|
||||
|
@@ -4,7 +4,7 @@ import org.junit.Assert;
|
||||
import org.junit.Test;
|
||||
|
||||
public class BooleanUtilTest {
|
||||
|
||||
|
||||
@Test
|
||||
public void toBooleanTest() {
|
||||
Assert.assertTrue(BooleanUtil.toBoolean("true"));
|
||||
@@ -16,7 +16,7 @@ public class BooleanUtilTest {
|
||||
Assert.assertTrue(BooleanUtil.toBoolean("是"));
|
||||
Assert.assertTrue(BooleanUtil.toBoolean("对"));
|
||||
Assert.assertTrue(BooleanUtil.toBoolean("真"));
|
||||
|
||||
|
||||
Assert.assertFalse(BooleanUtil.toBoolean("false"));
|
||||
Assert.assertFalse(BooleanUtil.toBoolean("6455434"));
|
||||
Assert.assertFalse(BooleanUtil.toBoolean(""));
|
||||
@@ -39,4 +39,37 @@ public class BooleanUtilTest {
|
||||
Assert.assertTrue(BooleanUtil.xor(true,false));
|
||||
Assert.assertTrue(BooleanUtil.xorOfWrap(true,false));
|
||||
}
|
||||
|
||||
public void orOfWrapTest() {
|
||||
Assert.assertFalse(BooleanUtil.orOfWrap(Boolean.FALSE, null));
|
||||
Assert.assertTrue(BooleanUtil.orOfWrap(Boolean.TRUE, null));
|
||||
}
|
||||
|
||||
@SuppressWarnings("ConstantConditions")
|
||||
@Test
|
||||
public void isTrueIsFalseTest() {
|
||||
Assert.assertFalse(BooleanUtil.isTrue(null));
|
||||
Assert.assertFalse(BooleanUtil.isFalse(null));
|
||||
}
|
||||
|
||||
@SuppressWarnings("ConstantConditions")
|
||||
public void negateTest() {
|
||||
Assert.assertFalse(BooleanUtil.negate(Boolean.TRUE));
|
||||
Assert.assertTrue(BooleanUtil.negate(Boolean.FALSE));
|
||||
|
||||
Assert.assertFalse(BooleanUtil.negate(Boolean.TRUE.booleanValue()));
|
||||
Assert.assertTrue(BooleanUtil.negate(Boolean.FALSE.booleanValue()));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void toStringTest() {
|
||||
Assert.assertEquals("true", BooleanUtil.toStringTrueFalse(true));
|
||||
Assert.assertEquals("false", BooleanUtil.toStringTrueFalse(false));
|
||||
|
||||
Assert.assertEquals("yes", BooleanUtil.toStringYesNo(true));
|
||||
Assert.assertEquals("no", BooleanUtil.toStringYesNo(false));
|
||||
|
||||
Assert.assertEquals("on", BooleanUtil.toStringOnOff(true));
|
||||
Assert.assertEquals("off", BooleanUtil.toStringOnOff(false));
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user