/*
* Copyright (C) 2014 Red Hat, Inc. and/or its affiliates.
*
* 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 org.jboss.errai.security.client.local;
import static org.jboss.errai.bus.client.api.base.MessageBuilder.*;
import org.jboss.errai.common.client.api.RemoteCallback;
import org.jboss.errai.ioc.client.container.IOC;
import org.jboss.errai.security.client.local.res.ClientInterceptorTestAssistant;
import org.jboss.errai.security.client.local.res.Counter;
import org.jboss.errai.security.client.shared.AdminService;
import org.jboss.errai.security.client.shared.AuthenticatedService;
import org.jboss.errai.security.client.shared.DiverseService;
import org.jboss.errai.security.shared.api.identity.User;
public class ClientBusSecurityInterceptorTest extends BusSecurityInterceptorTest {
@Override
protected void postLogout() {
}
@Override
protected void postLogin(User user) {
}
@Override
protected void gwtSetUp() throws Exception {
ClientInterceptorTestAssistant.active = true;
super.gwtSetUp();
}
public void testAuthInterceptorRedirectsWithNoErrorHandler() throws Exception {
asyncTest();
runNavTest(new Runnable() {
@Override
public void run() {
final TestLoginPage page = IOC.getBeanManager().lookupBean(TestLoginPage.class).getInstance();
assertEquals(0, page.getPageLoadCounter());
// Invalidate cache
provider.setUser(User.ANONYMOUS);
assertTrue(provider.isValid());
createCall(new RemoteCallback<Void>() {
@Override
public void callback(Void response) {
fail();
}
}, AuthenticatedService.class).userStuff();
testUntil(TIME_LIMIT, new Runnable() {
@Override
public void run() {
assertEquals(1, page.getPageLoadCounter());
}
});
}
});
}
public void testRoleInterceptorRedirectsToLoginWhenNotLoggedInAndNoErrorHandler() throws Exception {
asyncTest();
final Counter counter = new Counter();
runNavTest(new Runnable() {
@Override
public void run() {
final TestLoginPage page = IOC.getBeanManager().lookupBean(TestLoginPage.class).getInstance();
assertEquals(0, page.getPageLoadCounter());
// Invalidate cache
provider.setUser(User.ANONYMOUS);
assertTrue(provider.isValid());
assertEquals(0, counter.getCount());
createCall(new RemoteCallback<Void>() {
@Override
public void callback(Void response) {
counter.increment();
}
}, AdminService.class).adminStuff();
testUntil(TIME_LIMIT, new Runnable() {
@Override
public void run() {
assertEquals(0, counter.getCount());
assertEquals(1, page.getPageLoadCounter());
}
});
}
});
}
public void testRoleInterceptorLoggedInUnprivelegedRedirectsToSecurityErrorWithNoErrorCallback() throws Exception {
asyncTest();
final Counter counter = new Counter();
runNavTest(new Runnable() {
@Override
public void run() {
final TestSecurityErrorPage page = IOC.getBeanManager().lookupBean(TestSecurityErrorPage.class).getInstance();
assertEquals(0, page.getPageLoadCounter());
afterLogin("john", "123", new RemoteCallback<User>() {
@Override
public void callback(User response) {
assertEquals(0, counter.getCount());
createCall(new RemoteCallback<Void>() {
@Override
public void callback(Void response) {
counter.increment();
}
}, DiverseService.class).adminOnly();
testUntil(TIME_LIMIT, new Runnable() {
@Override
public void run() {
assertEquals(0, counter.getCount());
assertEquals(1, page.getPageLoadCounter());
}
});
}
});
}
});
}
}