/* * Copyright 2010-2017 Steve Chaloner * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package be.objectify.deadbolt.java.composite; import be.objectify.deadbolt.java.DeadboltHandler; import org.junit.Assert; import org.junit.Test; import org.mockito.Mockito; import play.libs.F; import play.mvc.Http; import java.util.Optional; import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; import java.util.concurrent.Executors; import java.util.function.Function; /** * @author Steve Chaloner (steve@objectify.be) */ public class ConstraintTreeTest extends AbstractConstraintTest { private final Http.Context context = Mockito.mock(Http.Context.class); private final DeadboltHandler handler = Mockito.mock(DeadboltHandler.class); @Test public void testAnd_false_false() throws Exception { final Constraint constraint = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(false); final Constraint tree = new ConstraintTree(Operator.AND, constraint, constraint); final CompletionStage<Boolean> result = tree.test(context, handler, Executors.newSingleThreadExecutor()); Assert.assertFalse(toBoolean(result)); } @Test public void testAnd_true_false() throws Exception { final Constraint c1 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(true); final Constraint c2 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(false); final Constraint tree = new ConstraintTree(Operator.AND, c1, c2); final CompletionStage<Boolean> result = tree.test(context, handler, Executors.newSingleThreadExecutor()); Assert.assertFalse(toBoolean(result)); } @Test public void testAnd_false_true() throws Exception { final Constraint c1 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(false); final Constraint c2 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(true); final Constraint tree = new ConstraintTree(Operator.AND, c1, c2); final CompletionStage<Boolean> result = tree.test(context, handler, Executors.newSingleThreadExecutor()); Assert.assertFalse(toBoolean(result)); } @Test public void testAnd_true_true() throws Exception { final Constraint c1 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(true); final Constraint c2 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(true); final Constraint tree = new ConstraintTree(Operator.AND, c1, c2); final CompletionStage<Boolean> result = tree.test(context, handler, Executors.newSingleThreadExecutor()); Assert.assertTrue(toBoolean(result)); } @Test public void testOr_false_false() throws Exception { final Constraint constraint = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(false); final Constraint tree = new ConstraintTree(Operator.OR, constraint, constraint); final CompletionStage<Boolean> result = tree.test(context, handler, Executors.newSingleThreadExecutor()); Assert.assertFalse(toBoolean(result)); } @Test public void testOr_true_false() throws Exception { final Constraint c1 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(true); final Constraint c2 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(false); final Constraint tree = new ConstraintTree(Operator.OR, c1, c2); final CompletionStage<Boolean> result = tree.test(context, handler, Executors.newSingleThreadExecutor()); Assert.assertTrue(toBoolean(result)); } @Test public void testOr_false_true() throws Exception { final Constraint c1 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(false); final Constraint c2 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(true); final Constraint tree = new ConstraintTree(Operator.OR, c1, c2); final CompletionStage<Boolean> result = tree.test(context, handler, Executors.newSingleThreadExecutor()); Assert.assertTrue(toBoolean(result)); } @Test public void testOr_true_true() throws Exception { final Constraint c1 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(true); final Constraint c2 = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(true); final Constraint tree = new ConstraintTree(Operator.OR, c1, c2); final CompletionStage<Boolean> result = tree.test(context, handler, Executors.newSingleThreadExecutor()); Assert.assertTrue(toBoolean(result)); } @Test public void testMeta_and() throws Exception { final Constraint c1 = (c, h, e, gmd, fnM) -> gmd.map(meta -> CompletableFuture.completedFuture("foo".equals(meta))) .orElse(CompletableFuture.completedFuture(false)); final Constraint c2 = (c, h, e, gmd, fnM) -> gmd.map(meta -> CompletableFuture.completedFuture("foo".equals(meta))) .orElse(CompletableFuture.completedFuture(false)); final Constraint tree = new ConstraintTree(Operator.AND, c1, c2); final CompletionStage<Boolean> result = tree.test(context, handler, Executors.newSingleThreadExecutor(), Optional.of("foo"), (md1, md2) -> md1); Assert.assertTrue(toBoolean(result)); } @Test public void testMeta_or() throws Exception { final Constraint c1 = (c, h, e, gmd, fnM) -> gmd.map(meta -> CompletableFuture.completedFuture("foo".equals(meta))) .orElse(CompletableFuture.completedFuture(false)); final Constraint c2 = (c, h, e, gmd, fnM) -> gmd.map(meta -> CompletableFuture.completedFuture("foo".equals(meta))) .orElse(CompletableFuture.completedFuture(false)); final CompletionStage<Boolean> leftResult = new ConstraintTree(Operator.OR, c1, c2).test(context, handler, Executors.newSingleThreadExecutor(), Optional.of("foo"), (md1, md2) -> md1); Assert.assertTrue(toBoolean(leftResult)); final CompletionStage<Boolean> rightResult = new ConstraintTree(Operator.OR, (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(false), c2).test(context, handler, Executors.newSingleThreadExecutor(), Optional.of("foo"), (md1, md2) -> md1); Assert.assertTrue(toBoolean(rightResult)); } @Override protected F.Tuple<Constraint, Function<Constraint, CompletionStage<Boolean>>> satisfy() { final Constraint constraint = (c, h, e, gmd, fnM) -> CompletableFuture.completedFuture(true); final Constraint tree = new ConstraintTree(Operator.AND, constraint, constraint); return new F.Tuple<>(tree, c -> c.test(context, handler, Executors.newSingleThreadExecutor())); } }