summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarecor M. Baclay <mbaclay@apache.org>2009-07-29 06:22:40 +0000
committerMarecor M. Baclay <mbaclay@apache.org>2009-07-29 06:22:40 +0000
commit7b15e3da49464440b849efe72b65a354f29a9b85 (patch)
tree78113fbe0161275e3eefadf3c89f841f7d49f98e
parenta37878dc223d93b000961aa6e71dc4a6fdc6b5f6 (diff)
downloadarchiva-7b15e3da49464440b849efe72b65a354f29a9b85.tar.gz
archiva-7b15e3da49464440b849efe72b65a354f29a9b85.zip
[MRM-1226] Selenium tests for Repositories and Network Proxies
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@798789 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--archiva-modules/archiva-web/archiva-webapp-test/src/test/testng/org/apache/archiva/web/test/NetworkProxiesTest.java96
-rw-r--r--archiva-modules/archiva-web/archiva-webapp-test/src/test/testng/org/apache/archiva/web/test/RepositoryTest.java146
2 files changed, 242 insertions, 0 deletions
diff --git a/archiva-modules/archiva-web/archiva-webapp-test/src/test/testng/org/apache/archiva/web/test/NetworkProxiesTest.java b/archiva-modules/archiva-web/archiva-webapp-test/src/test/testng/org/apache/archiva/web/test/NetworkProxiesTest.java
new file mode 100644
index 000000000..b12a096b8
--- /dev/null
+++ b/archiva-modules/archiva-web/archiva-webapp-test/src/test/testng/org/apache/archiva/web/test/NetworkProxiesTest.java
@@ -0,0 +1,96 @@
+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 org.apache.archiva.web.test.parent.AbstractRepositoryTest;
+import org.testng.annotations.Test;
+
+@Test( groups = { "networkproxies" }, dependsOnMethods = { "testWithCorrectUsernamePassword" } )
+public class NetworkProxiesTest
+ extends AbstractRepositoryTest
+{
+ @Test (dependsOnMethods = { "testDeleteRepositoryGroup" } )
+ public void testAddNetworkProxyNullValues()
+ {
+ goToNetworkProxiesPage();
+ addNetworkProxy( "", "", "", "", "", "");
+ assertTextPresent( "You must enter an identifier." );
+ assertTextPresent( "You must enter a protocol." );
+ assertTextPresent( "You must enter a host." );
+ }
+
+ @Test (dependsOnMethods = { "testAddNetworkProxyNullValues" } )
+ public void testAddNetworkProxyNullIdentifier()
+ {
+ goToNetworkProxiesPage();
+ addNetworkProxy( "", "http", "localhost", "8080", "", "");
+ assertTextPresent( "You must enter an identifier." );
+ }
+
+ @Test (dependsOnMethods = { "testAddNetworkProxyNullIdentifier" } )
+ public void testAddNetworkProxyNullProtocol()
+ {
+ goToNetworkProxiesPage();
+ addNetworkProxy( "testing123", "", "localhost", "8080", "", "");
+ assertTextPresent( "You must enter a protocol." );
+ }
+
+ @Test (dependsOnMethods = { "testAddNetworkProxyNullProtocol" } )
+ public void testAddNetworkProxiesNullHostname()
+ {
+ goToNetworkProxiesPage();
+ addNetworkProxy( "testing123", "http", "", "8080", "", "");
+ assertTextPresent( "You must enter a host." );
+ }
+
+ @Test (dependsOnMethods = { "testAddNetworkProxiesNullHostname" } )
+ public void testAddNetworkProxiesValidValues()
+ {
+ goToNetworkProxiesPage();
+ addNetworkProxy( "testing123", "http", "localhost", "8080", "", "");
+ assertPage( "Apache Archiva \\ Administration - Network Proxies" );
+ assertTextPresent( "testing123" );
+ }
+
+ @Test (dependsOnMethods = { "testAddNetworkProxiesValidValues" } )
+ public void testEditNetworkProxy()
+ {
+ editNetworkProxies( "proxy.host", "localhost" );
+ assertPage( "Apache Archiva \\ Administration - Network Proxies" );
+ assertTextPresent( "localhost" );
+ }
+
+ @Test (dependsOnMethods = { "testEditNetworkProxy" } )
+ public void testDeleteNetworkProxy()
+ {
+ deleteNetworkProxy();
+ assertPage( "Apache Archiva \\ Administration - Network Proxies" );
+ assertTextPresent( "There are no network proxies configured yet." );
+ }
+
+ @Test (dependsOnMethods = { "testDeleteNetworkProxy" } )
+ public void testAddNetworkProxyAfterDelete()
+ {
+ addNetworkProxy( "testing123", "http", "localhost", "8080", "", "");
+ assertPage( "Apache Archiva \\ Administration - Network Proxies" );
+ assertTextPresent( "testing123" );
+ }
+
+}
diff --git a/archiva-modules/archiva-web/archiva-webapp-test/src/test/testng/org/apache/archiva/web/test/RepositoryTest.java b/archiva-modules/archiva-web/archiva-webapp-test/src/test/testng/org/apache/archiva/web/test/RepositoryTest.java
new file mode 100644
index 000000000..9ae70ed30
--- /dev/null
+++ b/archiva-modules/archiva-web/archiva-webapp-test/src/test/testng/org/apache/archiva/web/test/RepositoryTest.java
@@ -0,0 +1,146 @@
+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 org.apache.archiva.web.test.parent.AbstractRepositoryTest;
+import org.testng.annotations.Test;
+
+@Test( groups = { "repository" }, dependsOnMethods = { "testWithCorrectUsernamePassword" } )
+public class RepositoryTest
+ extends AbstractRepositoryTest
+{
+ public void testAddManagedRepoValidValues()
+ {
+ goToRepositoriesPage();
+ clickLinkWithText( "Add" );
+ addManagedRepository( "managedrepo1", "Managed Repository Sample 1" , getRepositoryDir() + "repository/" , "", "Maven 2.x Repository", "0 0 * * * ?", "", "" );
+ clickButtonWithValue( "Save" );
+ assertTextPresent( "Managed Repository Sample 1" );
+
+ }
+
+ @Test(dependsOnMethods = { "testAddManagedRepoValidValues" } )
+ public void testAddManagedRepoInvalidValues()
+ {
+ goToRepositoriesPage();
+ clickLinkWithText( "Add" );
+ addManagedRepository( "", "" , "" , "", "Maven 2.x Repository", "", "", "" );
+ assertTextPresent( "You must enter a repository identifier." );
+ assertTextPresent( "You must enter a repository name." );
+ assertTextPresent( "You must enter a directory." );
+ assertTextPresent( "Invalid cron expression." );
+ }
+
+ @Test(dependsOnMethods = { "testAddManagedRepoInvalidValues" } )
+ public void testAddManagedRepoNoIdentifier()
+ {
+ //goToRepositoriesPage();
+ addManagedRepository( "", "name" , "/home" , "/.index", "Maven 2.x Repository", "0 0 * * * ?", "", "" );
+ assertTextPresent( "You must enter a repository identifier." );
+ }
+
+ @Test(dependsOnMethods = { "testAddManagedRepoNoIdentifier" } )
+ public void testAddManagedRepoNoRepoName()
+ {
+ addManagedRepository( "identifier", "" , "/home" , "/.index", "Maven 2.x Repository", "0 0 * * * ?", "", "" );
+ assertTextPresent( "You must enter a repository name." );
+ }
+
+ @Test(dependsOnMethods = { "testAddManagedRepoNoRepoName" } )
+ public void testAddManagedRepoNoDirectory()
+ {
+ addManagedRepository( "identifier", "name" , "" , "/.index", "Maven 2.x Repository", "0 0 * * * ?", "", "" );
+ assertTextPresent( "You must enter a directory." );
+ }
+
+ @Test(dependsOnMethods = { "testAddManagedRepoNoDirectory" } )
+ public void testAddManagedRepoNoCron()
+ {
+ addManagedRepository( "identifier", "name" , "/home" , "/.index", "Maven 2.x Repository", "", "", "" );
+ assertTextPresent( "Invalid cron expression." );
+ }
+
+ @Test(dependsOnMethods = { "testAddManagedRepoNoCron" } )
+ public void testAddManagedRepoForEdit()
+ {
+ goToRepositoriesPage();
+ clickLinkWithText( "Add" );
+ addManagedRepository( "managedrepo", "Managed Repository Sample" , getRepositoryDir() + "local-repo/", "", "Maven 2.x Repository", "0 0 * * * ?", "", "" );
+ clickButtonWithValue( "Save" );
+ assertTextPresent( "Managed Repository Sample" );
+ }
+
+ //TODO
+ @Test(dependsOnMethods = { "testAddManagedRepoForEdit" } )
+ public void testEditManagedRepo()
+ {
+ editManagedRepository( "repository.name" , "Managed Repo" );
+ assertTextPresent( "Managed Repository Sample" );
+ }
+
+ //TODO
+ @Test(dependsOnMethods = { "testEditManagedRepo" } )
+ public void testDeleteManageRepo()
+ {
+ deleteManagedRepository();
+ //assertTextNotPresent( "managedrepo" );
+ }
+
+ @Test(dependsOnMethods = { "testAddManagedRepoValidValues" } )
+ public void testAddRemoteRepoNullValues()
+ {
+ //goToRepositoriesPage();
+ clickLinkWithLocator( "//div[@id='contentArea']/div/div[5]/a" );
+ addRemoteRepository( "" , "" , "" , "" , "" , "" , "Maven 2.x Repository" );
+ assertTextPresent( "You must enter a repository identifier." );
+ assertTextPresent( "You must enter a repository name." );
+ assertTextPresent( "You must enter a url." );
+ }
+
+ @Test(dependsOnMethods = { "testAddRemoteRepoNullValues" } )
+ public void testAddRemoteRepositoryNullIdentifier()
+ {
+ addRemoteRepository( "" , "Remote Repository Sample" , "http://repository.codehaus.org/org/codehaus/mojo/" , "" , "" , "" , "Maven 2.x Repository" );
+ assertTextPresent( "You must enter a repository identifier." );
+ }
+
+ @Test(dependsOnMethods = { "testAddRemoteRepositoryNullIdentifier" } )
+ public void testAddRemoteRepoNullName()
+ {
+ addRemoteRepository( "remoterepo" , "" , "http://repository.codehaus.org/org/codehaus/mojo/" , "" , "" , "" , "Maven 2.x Repository" );
+ assertTextPresent( "You must enter a repository name." );
+ }
+
+ @Test(dependsOnMethods = { "testAddRemoteRepoNullName" } )
+ public void testAddRemoteRepoNullURL()
+ {
+ addRemoteRepository( "remoterepo" , "Remote Repository Sample" , "" , "" , "" , "" , "Maven 2.x Repository" );
+ assertTextPresent( "You must enter a url." );
+ }
+
+ @Test(dependsOnMethods = { "testAddManagedRepoValidValues" } )
+ public void testAddRemoteRepoValidValues()
+ {
+ goToRepositoriesPage();
+ clickLinkWithLocator( "//div[@id='contentArea']/div/div[5]/a" );
+ addRemoteRepository( "remoterepo" , "Remote Repository Sample" , "http://repository.codehaus.org/org/codehaus/mojo/" , "" , "" , "" , "Maven 2.x Repository" );
+ assertTextPresent( "Remote Repository Sample" );
+ }
+}