diff --git a/src/test/java/option/OptionalExample.java b/src/test/java/option/OptionalExample.java index db18993..e21432a 100644 --- a/src/test/java/option/OptionalExample.java +++ b/src/test/java/option/OptionalExample.java @@ -4,13 +4,25 @@ import java.util.Optional; import java.util.concurrent.ThreadLocalRandom; +import java.util.function.BiFunction; import java.util.function.Function; +import java.util.function.Predicate; +import java.util.function.Supplier; import static org.junit.Assert.assertEquals; public class OptionalExample { - @Test + public static Optional zipMap(Optional o1, Optional o2, BiFunction bf) { + return o1.flatMap(t1 -> o2.map(t2 -> bf.apply(t1, t2))); + } + + public static Optional zipMap1(Optional o1, Optional o2, BiFunction bf) { + Optional> optionalOptional = o1.map(t1 -> o2.map(t2 -> bf.apply(t1, t2))); + return optionalOptional.orElse(Optional.empty()); + } + + @Test(expected = UnsupportedOperationException.class) public void get() { final Optional o1 = Optional.empty(); @@ -50,6 +62,111 @@ public void map() { assertEquals(expected, actual); } + @Test + public void filter() throws Exception { + Optional o1 = getOptional(); + + Predicate p = s -> s.equals("abc"); + + Optional expected = o1.filter(p); + Optional actual; + + if (o1.isPresent()) { + if (p.test(o1.get())) { + actual = o1; + } else { + actual = Optional.empty(); + } + } else { + actual = Optional.empty(); + } + + assertEquals(expected, actual); + } + + @Test + public void flatMap() throws Exception { + Optional o1 = getOptional(); + + Function> f = s -> Optional.of("test"); + + Optional expected = o1.flatMap(f); + Optional actual; + + if (o1.isPresent()) { + actual = f.apply(o1.get()); + } else { + actual = Optional.empty(); + } + + assertEquals(expected, actual); + } + + @Test + public void orElse() throws Exception { + Optional o1 = getOptional(); + + String str = "test"; + + String expected = o1.orElse(str); + String actual; + + if (o1.isPresent()) { + actual = o1.get(); + } else { + actual = str; + } + + assertEquals(expected, actual); + } + + @Test + public void orElseGet() throws Exception { + Optional o1 = getOptional(); + + Supplier supplier = () -> "test"; + + String expected = o1.orElseGet(supplier); + String actual; + + if (o1.isPresent()) { + actual = o1.get(); + } else { + actual = supplier.get(); + } + + assertEquals(expected, actual); + } + + @Test + public void orElseThrow() throws Exception { + Optional o1 = getOptional(); + Supplier thrower = NullPointerException::new; + + boolean thrownedExpected = false; + String expected = null; + try { + expected = o1.orElseThrow(thrower); + } catch (NullPointerException e) { + thrownedExpected = true; + } + + boolean thrownedActual = false; + String actual = null; + try { + if (o1.isPresent()) { + actual = o1.get(); + } else { + thrower.get(); + } + } catch (NullPointerException e) { + thrownedActual = true; + } + + assertEquals(thrownedExpected, thrownedActual); + assertEquals(expected, actual); + } + private Optional getOptional() { return ThreadLocalRandom.current().nextBoolean() ? Optional.empty()