Fix Javadoc bug; Improve implementation and tests
git-svn-id: https://svn.apache.org/repos/asf/commons/proper/lang/trunk@1133336 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
6887d0f09c
commit
734d218eb5
|
@ -698,8 +698,6 @@ public class BooleanUtils {
|
||||||
/**
|
/**
|
||||||
* <p>Converts a String to a Boolean throwing an exception if no match found.</p>
|
* <p>Converts a String to a Boolean throwing an exception if no match found.</p>
|
||||||
*
|
*
|
||||||
* <p>null is returned if there is no match.</p>
|
|
||||||
*
|
|
||||||
* <pre>
|
* <pre>
|
||||||
* BooleanUtils.toBoolean("true", "true", "false") = true
|
* BooleanUtils.toBoolean("true", "true", "false") = true
|
||||||
* BooleanUtils.toBoolean("false", "true", "false") = false
|
* BooleanUtils.toBoolean("false", "true", "false") = false
|
||||||
|
@ -712,17 +710,16 @@ public class BooleanUtils {
|
||||||
* @throws IllegalArgumentException if the String doesn't match
|
* @throws IllegalArgumentException if the String doesn't match
|
||||||
*/
|
*/
|
||||||
public static boolean toBoolean(String str, String trueString, String falseString) {
|
public static boolean toBoolean(String str, String trueString, String falseString) {
|
||||||
if (str == null) {
|
if (str == trueString) {
|
||||||
if (trueString == null) {
|
return true;
|
||||||
|
} else if (str == falseString) {
|
||||||
|
return false;
|
||||||
|
} else if (str != null) {
|
||||||
|
if (str.equals(trueString)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
} else if (str.equals(falseString)) {
|
||||||
if (falseString == null) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} else if (str.equals(trueString)) {
|
|
||||||
return true;
|
|
||||||
} else if (str.equals(falseString)) {
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
// no match
|
// no match
|
||||||
throw new IllegalArgumentException("The String did not match either specified value");
|
throw new IllegalArgumentException("The String did not match either specified value");
|
||||||
|
|
|
@ -327,13 +327,10 @@ public class BooleanUtilsTest extends TestCase {
|
||||||
public void test_toBoolean_String_String_String() {
|
public void test_toBoolean_String_String_String() {
|
||||||
assertEquals(true, BooleanUtils.toBoolean((String) null, null, "N"));
|
assertEquals(true, BooleanUtils.toBoolean((String) null, null, "N"));
|
||||||
assertEquals(false, BooleanUtils.toBoolean((String) null, "Y", null));
|
assertEquals(false, BooleanUtils.toBoolean((String) null, "Y", null));
|
||||||
try {
|
|
||||||
BooleanUtils.toBooleanObject((String) null, "Y", "N", "U");
|
|
||||||
fail();
|
|
||||||
} catch (IllegalArgumentException ex) {}
|
|
||||||
|
|
||||||
assertEquals(true, BooleanUtils.toBoolean("Y", "Y", "N"));
|
assertEquals(true, BooleanUtils.toBoolean("Y", "Y", "N"));
|
||||||
|
assertEquals(true, BooleanUtils.toBoolean("Y", new String("Y"), new String("N")));
|
||||||
assertEquals(false, BooleanUtils.toBoolean("N", "Y", "N"));
|
assertEquals(false, BooleanUtils.toBoolean("N", "Y", "N"));
|
||||||
|
assertEquals(false, BooleanUtils.toBoolean("N", new String("Y"), new String("N")));
|
||||||
try {
|
try {
|
||||||
BooleanUtils.toBoolean(null, "Y", "N");
|
BooleanUtils.toBoolean(null, "Y", "N");
|
||||||
fail();
|
fail();
|
||||||
|
@ -342,6 +339,9 @@ public class BooleanUtilsTest extends TestCase {
|
||||||
BooleanUtils.toBoolean("X", "Y", "N");
|
BooleanUtils.toBoolean("X", "Y", "N");
|
||||||
fail();
|
fail();
|
||||||
} catch (IllegalArgumentException ex) {}
|
} catch (IllegalArgumentException ex) {}
|
||||||
|
assertEquals(true, BooleanUtils.toBoolean((String) null, null, null));
|
||||||
|
assertEquals(true, BooleanUtils.toBoolean("Y", "Y", "Y"));
|
||||||
|
assertEquals(true, BooleanUtils.toBoolean("Y", new String("Y"), new String("Y")));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
//-----------------------------------------------------------------------
|
||||||
|
|
Loading…
Reference in New Issue