/*******************************************************************************
* Copyright (c) 2010-2013 Red Hat, Inc.
* Distributed under license by Red Hat, Inc. All rights reserved.
* This program is made available under the terms of the
* Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Red Hat, Inc. - initial API and implementation
******************************************************************************/
package org.jboss.tools.deltaspike.ui.bot.test;
import org.jboss.ide.eclipse.as.reddeer.server.requirement.ServerRequirement;
import org.jboss.reddeer.common.matcher.RegexMatcher;
import org.jboss.reddeer.common.wait.TimePeriod;
import org.jboss.reddeer.common.wait.WaitUntil;
import org.jboss.reddeer.common.wait.WaitWhile;
import org.jboss.reddeer.jface.text.contentassist.ContentAssistant;
import org.jboss.reddeer.junit.requirement.inject.InjectRequirement;
import org.jboss.reddeer.workbench.impl.editor.TextEditor;
import org.jboss.tools.deltaspike.ui.bot.test.condition.SpecificProblemExists;
import org.junit.After;
import org.junit.Test;
/**
* Test @Secured annotation, two approaches:
*
* 1. When there are multiple authorizer methods
* 2. When there is no authorizer method
*
* @author jjankovi
*
*/
public class SecuredAnnotationTest extends DeltaspikeTestBase {
private RegexMatcher ambiguousAuthorizerProblemMatcher = new RegexMatcher("Ambiguous authorizers found.*");
private RegexMatcher noMatchingAuthorizerProblemMatcher = new RegexMatcher("No matching authorizer found.*");
@InjectRequirement
private static ServerRequirement sr;
@After
public void closeAllEditors() {
deleteAllProjects();
}
@Test
public void testAmbiguousAuthorizersOnMethod() {
testAmbiguousAuthorizers("ambiguousAuthorizersOnMethod", "doSomething");
}
@Test
public void testAmbiguousAuthorizersOnClass() {
testAmbiguousAuthorizers("ambiguousAuthorizersOnClass", "SecuredBean");
}
@Test
public void testNotDeclaredSecurityBindingInAuthorizerOnMethod() {
testNotDeclaredSecurityBindingInAuthorizer("noAuthorizerOnMethod", "doSomething");
}
@Test
public void testNotDeclaredSecurityBindingInAuthorizerOnClass() {
testNotDeclaredSecurityBindingInAuthorizer("noAuthorizerOnClass", "SecuredBean");
}
public void testAmbiguousAuthorizers(String projectName, String hyperlinkItem) {
importDeltaspikeProject(projectName, sr);
new WaitUntil(new SpecificProblemExists(ambiguousAuthorizerProblemMatcher), TimePeriod.LONG);
replaceInEditor(projectName, "test", "SecuredBean.java", "4", "1", true);
new WaitWhile(new SpecificProblemExists(ambiguousAuthorizerProblemMatcher), TimePeriod.LONG);
TextEditor e = new TextEditor("SecuredBean.java");
e.selectText(hyperlinkItem);
ContentAssistant ca = e.openOpenOnAssistant();
ca.chooseProposal("Open authorizer method CustomAuthorizer.check3()");
new TextEditor("CustomAuthorizer.java");
}
public void testNotDeclaredSecurityBindingInAuthorizer(String projectName, String hyperlinkItem) {
importDeltaspikeProject(projectName, sr);
new WaitUntil(new SpecificProblemExists(noMatchingAuthorizerProblemMatcher), TimePeriod.LONG);
replaceInEditor(projectName, "test", "SecuredBean.java", "1", "4", true);
new WaitWhile(new SpecificProblemExists(noMatchingAuthorizerProblemMatcher), TimePeriod.LONG);
TextEditor e = new TextEditor("SecuredBean.java");
e.selectText(hyperlinkItem);
ContentAssistant ca = e.openOpenOnAssistant();
ca.chooseProposal("Open authorizer method CustomAuthorizer.check()");
new TextEditor("CustomAuthorizer.java");
}
}