summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorskygo <skygo@unknown>2013-06-08 21:19:08 +0000
committerskygo <skygo@unknown>2013-06-08 21:19:08 +0000
commit0f64dcd52c58327a523770e9b70406befb80c5e2 (patch)
treeac0305b78f631d17d77be6011a32ac3327ab0c28
parentbfb3f8bd6297fbe5ad7978ef56f713a31e1b8b4f (diff)
downloadarchiva-0f64dcd52c58327a523770e9b70406befb80c5e2.tar.gz
archiva-0f64dcd52c58327a523770e9b70406befb80c5e2.zip
more work on test // need to feed fake artifact for testing MRM1766 and others
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1491062 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--archiva-modules/archiva-web/archiva-webapp-test/src/test/java/org/apache/archiva/web/test/WebDriverBrowseTest.java160
1 files changed, 160 insertions, 0 deletions
diff --git a/archiva-modules/archiva-web/archiva-webapp-test/src/test/java/org/apache/archiva/web/test/WebDriverBrowseTest.java b/archiva-modules/archiva-web/archiva-webapp-test/src/test/java/org/apache/archiva/web/test/WebDriverBrowseTest.java
new file mode 100644
index 000000000..bc96ad63f
--- /dev/null
+++ b/archiva-modules/archiva-web/archiva-webapp-test/src/test/java/org/apache/archiva/web/test/WebDriverBrowseTest.java
@@ -0,0 +1,160 @@
+package org.apache.archiva.web.test;
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you 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.
+ */
+
+import junit.framework.Assert;
+import org.apache.commons.lang3.StringUtils;
+import org.fluentlenium.adapter.FluentTest;
+import org.fluentlenium.core.domain.FluentList;
+import org.fluentlenium.core.domain.FluentWebElement;
+import static org.fest.assertions.Assertions.assertThat;
+import org.junit.Test;
+import org.openqa.selenium.WebDriver;
+import org.openqa.selenium.WebElement;
+import org.openqa.selenium.chrome.ChromeDriver;
+import org.openqa.selenium.firefox.FirefoxDriver;
+import org.openqa.selenium.ie.InternetExplorerDriver;
+import org.openqa.selenium.safari.SafariDriver;
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.IOException;
+import java.util.Properties;
+import java.util.concurrent.TimeUnit;
+import org.apache.commons.io.FileUtils;
+import org.fluentlenium.core.Fluent;
+import org.junit.Before;
+
+/**
+ * @author Olivier Lamy
+ */
+public class WebDriverBrowseTest
+ extends FluentTest
+{
+
+ @Override
+ public Fluent takeScreenShot( String fileName )
+ {
+ try
+ {
+ // save html to have a minimum feedback if jenkins firefox not up
+ File fileNameHTML = new File( fileName + ".html" );
+ FileUtils.writeStringToFile( fileNameHTML, getDriver().getPageSource() );
+ }
+ catch ( IOException e )
+ {
+ System.out.print( e.getMessage() );
+ e.printStackTrace();
+ }
+ return super.takeScreenShot( fileName );
+ }
+
+ @Before
+ public void init()
+ {
+ setSnapshotMode( Mode.TAKE_SNAPSHOT_ON_FAIL );
+ setSnapshotPath( new File( "target", "errorshtmlsnap" ).getAbsolutePath() );
+ }
+
+ @Test
+ public void simpletest()
+ throws Exception
+ {
+ Properties p = new Properties();
+ p.load( this.getClass().getClassLoader().getResourceAsStream( "test.properties" ) );
+
+ Properties tomcatPortProperties = new Properties();
+ tomcatPortProperties.load(
+ new FileInputStream( new File( System.getProperty( "tomcat.propertiesPortFilePath" ) ) ) );
+
+ int tomcatPort = Integer.parseInt( tomcatPortProperties.getProperty( "tomcat.maven.http.port" ) );
+
+ goTo( "http://localhost:" + tomcatPort + "/archiva/index.html?request_lang=en" );
+
+ // wait until topbar-menu-container is feeded
+ await().atMost( 5, TimeUnit.SECONDS ).until( "#topbar-menu" ).isPresent();
+
+ FluentList<FluentWebElement> elements = find( "#create-admin-link-a" );
+
+ if ( !elements.isEmpty() && elements.get( 0 ).isDisplayed() )
+ {
+ WebElement webElement = elements.get( 0 ).getElement();
+ Assert.assertEquals( "Create Admin User", webElement.getText() );
+
+ webElement.click();
+ await().atMost( 2, TimeUnit.SECONDS ).until( "#user-create" ).isPresent();
+ assertThat( find( "#username" ).getValue().equals( "admin" ) );
+ assertThat( find( "#password" ).getValue().isEmpty() );
+ assertThat( find( "#confirmPassword" ).getValue().isEmpty() );
+ assertThat( find( "#email" ).getValue().isEmpty() );
+
+ fill( "#fullname" ).with( p.getProperty( "ADMIN_FULLNAME" ) );
+ fill( "#email" ).with( p.getProperty( "ADMIN_EMAIL" ) );
+ fill( "#password" ).with( p.getProperty( "ADMIN_PASSWORD" ) );
+ fill( "#confirmPassword" ).with( p.getProperty( "ADMIN_PASSWORD" ) );
+ find( "#user-create-form-register-button" ).click();
+
+ await().atMost( 2, TimeUnit.SECONDS ).until( "#logout-link" ).isPresent();
+
+ FluentList<FluentWebElement> elementss = find( "#menu-find-browse-a" );
+ WebElement webElsement = elementss.get( 0 ).getElement();
+ webElsement.click();
+ await().atMost( 2, TimeUnit.SECONDS ).until( "#main_browse_result" ).isPresent();
+ // give me search page :( not browse page
+
+ takeScreenShot( "search" );
+
+ goTo( "http://localhost:" + tomcatPort + "/archiva/index.html#browse?request_lang=en" );
+ takeScreenShot( "browse" );
+ // give me a browse page
+
+ }
+ else
+ {
+ elements = find( "#login-link-a" );
+ WebElement webElement = elements.get( 0 ).getElement();
+ Assert.assertEquals( "LOGIN", webElement.getText() );
+ }
+
+ }
+
+ @Override
+ public WebDriver getDefaultDriver()
+ {
+ String seleniumBrowser = System.getProperty( "selenium.browser" );
+
+ if ( StringUtils.contains( seleniumBrowser, "chrome" ) )
+ {
+ return new ChromeDriver();
+ }
+
+ if ( StringUtils.contains( seleniumBrowser, "safari" ) )
+ {
+ return new SafariDriver();
+ }
+
+ if ( StringUtils.contains( seleniumBrowser, "iexplore" ) )
+ {
+ return new InternetExplorerDriver();
+ }
+
+ return new FirefoxDriver();
+
+ }
+}