/* * Copyright 2010-2016 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.views.patternTest; import be.objectify.deadbolt.java.AbstractDynamicResourceHandler; import be.objectify.deadbolt.java.AbstractFakeApplicationTest; import be.objectify.deadbolt.java.DeadboltHandler; import be.objectify.deadbolt.java.DynamicResourceHandler; import be.objectify.deadbolt.java.NoPreAuthDeadboltHandler; import be.objectify.deadbolt.java.cache.HandlerCache; import be.objectify.deadbolt.java.models.PatternType; import be.objectify.deadbolt.java.models.Subject; import be.objectify.deadbolt.java.testsupport.TestHandlerCache; import be.objectify.deadbolt.java.testsupport.TestPermission; import be.objectify.deadbolt.java.testsupport.TestSubject; import org.junit.Assert; import org.junit.Test; import play.mvc.Http; import play.test.Helpers; import play.twirl.api.Content; import java.util.HashMap; import java.util.Optional; import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; /** * @author Steve Chaloner (steve@objectify.be) */ public class PatternTest extends AbstractFakeApplicationTest { @Test public void testEquality_hasEqualPermission() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<? extends Subject>> getSubject(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new TestSubject.Builder().permission(new TestPermission("killer.undead.zombie")) .build())); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.zombie", PatternType.EQUALITY, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertTrue(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testEquality_doesNotHaveEqualPermission() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<? extends Subject>> getSubject(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new TestSubject.Builder().permission(new TestPermission("killer.undead.vampire")) .build())); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.zombie", PatternType.EQUALITY, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertFalse(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testEquality_doesNotHavePermissions() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<? extends Subject>> getSubject(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new TestSubject.Builder().build())); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.zombie", PatternType.EQUALITY, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertFalse(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testEquality_noSubject() { final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.zombie", PatternType.EQUALITY, new NoPreAuthDeadboltHandler(ecProvider()) { }); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertFalse(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testRegex_hasMatch() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<? extends Subject>> getSubject(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new TestSubject.Builder().permission(new TestPermission("killer.undead.zombie")) .build())); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.*", PatternType.REGEX, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertTrue(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testRegex_hasTopLevelMatch() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<? extends Subject>> getSubject(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new TestSubject.Builder().permission(new TestPermission("killer.undead.zombie")) .build())); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.*", PatternType.REGEX, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertTrue(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testRegex_doesNotHaveMatch() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<? extends Subject>> getSubject(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new TestSubject.Builder().permission(new TestPermission("killer.undead.vampire")) .build())); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.pixies.*", PatternType.REGEX, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertFalse(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testRegex_doesNotHavePermissions() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<? extends Subject>> getSubject(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new TestSubject.Builder().build())); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.zombie", PatternType.REGEX, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertFalse(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testRegex_noSubject() { final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.zombie", PatternType.REGEX, new NoPreAuthDeadboltHandler(ecProvider()) { }); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertFalse(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testCustom_value() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<DynamicResourceHandler>> getDynamicResourceHandler(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new AbstractDynamicResourceHandler() { @Override public CompletionStage<Boolean> checkPermission(final String permissionValue, final Optional<String> meta, final DeadboltHandler deadboltHandler, final Http.Context ctx) { return CompletableFuture.completedFuture("killer.undead.zombie".equals(permissionValue)); } })); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.zombie", PatternType.CUSTOM, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertTrue(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testCustom_hasPermission() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<DynamicResourceHandler>> getDynamicResourceHandler(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new AbstractDynamicResourceHandler() { @Override public CompletionStage<Boolean> checkPermission(final String permissionValue, final Optional<String> meta, final DeadboltHandler deadboltHandler, final Http.Context ctx) { return CompletableFuture.completedFuture(true); } })); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.zombie", PatternType.CUSTOM, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertTrue(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } @Test public void testCustom_hasNotPermission() { final DeadboltHandler deadboltHandler = new NoPreAuthDeadboltHandler(ecProvider()) { @Override public CompletionStage<Optional<DynamicResourceHandler>> getDynamicResourceHandler(final Http.Context context) { return CompletableFuture.supplyAsync(() -> Optional.of(new AbstractDynamicResourceHandler() { @Override public CompletionStage<Boolean> checkPermission(final String permissionValue, final Optional<String> meta, final DeadboltHandler deadboltHandler, final Http.Context ctx) { return CompletableFuture.completedFuture(false); } })); } }; final Content html = be.objectify.deadbolt.java.views.html.patternTest.patternContent.render("killer.undead.zombie", PatternType.CUSTOM, deadboltHandler); final String content = Helpers.contentAsString(html); Assert.assertTrue(content.contains("This is before the constraint.")); Assert.assertFalse(content.contains("This is protected by the constraint.")); Assert.assertTrue(content.contains("This is after the constraint.")); } public HandlerCache handlers() { // using new instances of handlers in the test return new TestHandlerCache(null, new HashMap<>()); } }