aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorJulien Lancelot <julien.lancelot@sonarsource.com>2016-06-28 11:02:44 +0200
committerJulien Lancelot <julien.lancelot@sonarsource.com>2016-06-29 08:44:00 +0200
commit46125ae42ed4ad5044fb94462f54a0cabe234b04 (patch)
treeb695d28603ff03599091f7762390757fe41994cc /tests
parentd26c3c28de38b01d6aa4106bd22769e41b76ef93 (diff)
downloadsonarqube-46125ae42ed4ad5044fb94462f54a0cabe234b04.tar.gz
sonarqube-46125ae42ed4ad5044fb94462f54a0cabe234b04.zip
SONAR-7759 Add checks on urls availability before and after upgrade
Diffstat (limited to 'tests')
-rw-r--r--tests/upgrade/pom.xml6
-rw-r--r--tests/upgrade/src/test/java/org/sonarsource/sonarqube/upgrade/UpgradeTest.java62
2 files changed, 68 insertions, 0 deletions
diff --git a/tests/upgrade/pom.xml b/tests/upgrade/pom.xml
index b9746c94fd1..908f167c573 100644
--- a/tests/upgrade/pom.xml
+++ b/tests/upgrade/pom.xml
@@ -21,6 +21,12 @@
</dependency>
<dependency>
<groupId>${project.groupId}</groupId>
+ <artifactId>sonar-ws</artifactId>
+ <version>${project.version}</version>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
+ <groupId>${project.groupId}</groupId>
<artifactId>sonar-application</artifactId>
<version>${project.version}</version>
<type>zip</type>
diff --git a/tests/upgrade/src/test/java/org/sonarsource/sonarqube/upgrade/UpgradeTest.java b/tests/upgrade/src/test/java/org/sonarsource/sonarqube/upgrade/UpgradeTest.java
index 08094969c2b..88eb5e55a1b 100644
--- a/tests/upgrade/src/test/java/org/sonarsource/sonarqube/upgrade/UpgradeTest.java
+++ b/tests/upgrade/src/test/java/org/sonarsource/sonarqube/upgrade/UpgradeTest.java
@@ -25,6 +25,7 @@ import com.sonar.orchestrator.Orchestrator;
import com.sonar.orchestrator.OrchestratorBuilder;
import com.sonar.orchestrator.build.MavenBuild;
import com.sonar.orchestrator.config.Configuration;
+import com.sonar.orchestrator.container.Server;
import com.sonar.orchestrator.locator.FileLocation;
import com.sonar.orchestrator.version.Version;
import java.io.File;
@@ -35,6 +36,11 @@ import org.apache.commons.io.IOUtils;
import org.junit.After;
import org.junit.Test;
import org.sonar.wsclient.services.ResourceQuery;
+import org.sonarqube.ws.client.GetRequest;
+import org.sonarqube.ws.client.HttpConnector;
+import org.sonarqube.ws.client.WsClient;
+import org.sonarqube.ws.client.WsClientFactories;
+import org.sonarqube.ws.client.WsResponse;
public class UpgradeTest {
@@ -70,8 +76,11 @@ public class UpgradeTest {
// latest version
startServer(Version.create(Orchestrator.builderEnv().getSonarVersion()), true);
checkSystemStatus(ServerStatusResponse.Status.DB_MIGRATION_NEEDED);
+ checkUrlsBeforeUpgrade();
+
upgradeDatabase();
checkSystemStatus(ServerStatusResponse.Status.UP);
+ checkUrlsAfterUpgrade();
assertThat(countFiles(PROJECT_KEY)).isEqualTo(files);
scanProject();
@@ -85,6 +94,38 @@ public class UpgradeTest {
assertThat(serverStatusResponse.getStatus()).isEqualTo(serverStatus);
}
+ private void checkUrlsBeforeUpgrade() {
+ // These urls should be available when system requires a migration
+ checkUrlIsReturningOk("/api/system/status");
+ checkUrlIsReturningOk("/api/system/db_migration_status");
+ checkUrlIsReturningOk("/api/webservices/list");
+
+ // These urls should not be available when system requires a migration
+ checkUrlIsReturningNotFound("/api/issues/search?projectKeys=org.apache.struts%3Astruts-core");
+ checkUrlIsReturningNotFound("/api/components/tree?baseComponentKey=org.apache.struts%3Astruts-core");
+ checkUrlIsReturningNotFound("/api/measures/component_tree?baseComponentKey=org.apache.struts%3Astruts-core&metricKeys=ncloc,files,violations");
+ checkUrlIsReturningNotFound("/api/qualityprofiles/search");
+
+ // These page should all redirect to maintenance page
+ checkUrlIsRedirectedToMaintenancePage("/");
+ checkUrlIsRedirectedToMaintenancePage("/issues/index");
+ checkUrlIsRedirectedToMaintenancePage("/dashboard/index/org.apache.struts:struts-parent");
+ checkUrlIsRedirectedToMaintenancePage("/issues/search");
+ checkUrlIsRedirectedToMaintenancePage("/component/index?id=org.apache.struts%3Astruts-core%3Asrc%2Fmain%2Fjava%2Forg%2Fapache%2Fstruts%2Fchain%2Fcommands%2Fgeneric%2FWrappingLookupCommand.java");
+ checkUrlIsRedirectedToMaintenancePage("/profiles");
+ }
+
+ private void checkUrlsAfterUpgrade() {
+ checkUrlIsReturningOk("/api/system/status");
+ checkUrlIsReturningOk("/api/system/db_migration_status");
+ checkUrlIsReturningOk("/api/webservices/list");
+
+ checkUrlIsReturningOk("/api/issues/search?projectKeys=org.apache.struts%3Astruts-core");
+ checkUrlIsReturningOk("/api/components/tree?baseComponentKey=org.apache.struts%3Astruts-core");
+ checkUrlIsReturningOk("/api/measures/component_tree?baseComponentKey=org.apache.struts%3Astruts-core&metricKeys=ncloc,files,violations");
+ checkUrlIsReturningOk("/api/qualityprofiles/search");
+ }
+
private void browseWebapp() {
testUrl("/");
testUrl("/api/issues/search?projectKeys=org.apache.struts%3Astruts-core");
@@ -161,4 +202,25 @@ public class UpgradeTest {
}
}
}
+
+ private void checkUrlIsReturningOk(String url) {
+ newWsClient(orchestrator).wsConnector().call(new GetRequest(url)).failIfNotSuccessful();
+ }
+
+ private void checkUrlIsReturningNotFound(String url) {
+ WsResponse response = newWsClient(orchestrator).wsConnector().call(new GetRequest(url));
+ assertThat(response.code()).isEqualTo(HttpURLConnection.HTTP_NOT_FOUND);
+ }
+
+ private void checkUrlIsRedirectedToMaintenancePage(String url) {
+ WsResponse response = newWsClient(orchestrator).wsConnector().call(new GetRequest(url)).failIfNotSuccessful();
+ assertThat(response.requestUrl()).contains("/maintenance");
+ }
+
+ private static WsClient newWsClient(Orchestrator orchestrator) {
+ Server server = orchestrator.getServer();
+ return WsClientFactories.getDefault().newClient(HttpConnector.newBuilder()
+ .url(server.getUrl())
+ .build());
+ }
}