/*
* JBoss, Home of Professional Open Source.
* Copyright 2010, Red Hat Middleware LLC, and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.gatein.selenium.jira;
import static org.jboss.gatein.selenium.common.CommonHelper.*;
import static org.jboss.gatein.selenium.navigation.NavigationHelper.deleteNode;
import static org.jboss.gatein.selenium.navigation.NavigationHelper.editNavigation;
import static org.jboss.gatein.selenium.page.PageHelper.addNewPageWithEditor;
import static org.jboss.gatein.selenium.page.PageHelper.searchAndDeletePage;
import org.jboss.gatein.selenium.AbstractContextual;
import org.jboss.gatein.selenium.AbstractSingleTestWithAnt;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;
/**
* @author <a href="mailto:mstrukel@redhat.com">Marko Strukelj</a>
*/
public class Test_GTNPORTAL_1257_SeamSessionOutlivesTheGateInSession extends AbstractSingleTestWithAnt {
@BeforeTest(alwaysRun = true)
public void deploySeamBooking() throws Exception {
if (!expectAntBuildFile()) {
log.warn("JBoss Portlet Bridge Seam Booking example may not be available");
return;
}
prepareAndExecuteAntBuild();
}
@Test(groups = { "GateIn", "jira" })
public void testGTNPORTAL_1257_SeamSessionOutlivesTheGateInSession() throws Throwable {
performTest();
}
@Override
protected void mainTest() throws Throwable {
try {
AbstractContextual.setTemporaryTimeoutSecInt(60); // give it at least one minute
openPortal(true);
} finally {
AbstractContextual.restoreTimeoutSecInt();
}
signInAsRoot();
goToApplicationRegistry();
installPortlet();
goToPage("Home");
try {
AbstractContextual.setTemporaryTimeoutSecInt(60); // give it at least one minute
addNewPageWithEditor(null, "TestPage", "TestPage", "portalBookingDemo", "seamBookingPortlet",
"//div[@id='portalBookingDemo/seamBookingPortlet']");
} catch (Throwable th) {
try {
leavePageEdit();
} catch (Exception ex) {
log.warn("IGNORED: ", ex);
}
throw th;
} finally {
AbstractContextual.restoreTimeoutSecInt();
}
waitForTextPresent("Search Hotels");
verifyTextPresent("Welcome, root");
signOut();
signInAsMary();
goToPage("TestPage");
waitForTextPresent("Search Hotels");
verifyTextPresent("Welcome, mary");
}
private void leavePageEdit() {
// we could have an error window popped up
String closeButton = "//div[@class='ExoMessageDecorator' and //div[@class='TabsContainer']//div[@class='SelectedTab']]//div[@class='CloseButton']";
click(closeButton);
// also we may have to abort
String abortButton = "//table[@class='ActionContainer']//div[contains(@onclick, 'action=Abort')]//a[text()='Abort']";
click(abortButton);
}
private void installPortlet() throws Throwable {
// try several times - to give dependency deployment some time
Throwable ex = null;
for (int i = 0; i < 3; i++) {
importApplications();
try {
verifyPortletInstalled("portalBookingDemo", "seamBookingPortlet");
return;
} catch (Throwable th) {
ex = th;
}
}
throw ex;
}
@Override
protected void exception(Throwable ex) {
log.error("Exception during test: ", ex);
}
@Override
protected void cleanup() {
System.out.println("\n== Cleanup ==");
try {
signOut();
} catch (Throwable e) {
log.warn("IGNORED: Failed to sign out: ", e);
}
try {
signInAsRoot();
} catch (Throwable e) {
log.warn("IGNORED: Failed to sign in as root: ", e);
}
try {
goToPageManagement();
searchAndDeletePage("TestPage");
} catch (Throwable e) {
log.warn("IGNORED: Failed to delete testPage: ", e);
}
try {
goToSiteManagement();
editNavigation("classic");
deleteNode("TestPage");
} catch (Throwable e) {
log.warn("IGNORED: Failed to remove TestPage from navigation: ", e);
}
try {
signOut();
} catch (Throwable e) {
log.warn("IGNORED: Failed to sign out: ", e);
}
}
}