diff options
author | Simon Brandhof <simon.brandhof@sonarsource.com> | 2016-08-03 15:47:18 +0200 |
---|---|---|
committer | Simon Brandhof <simon.brandhof@sonarsource.com> | 2016-08-03 17:59:19 +0200 |
commit | d033213dad868cafabf6b8a63c17cf8c4f20c753 (patch) | |
tree | ef3245f54a690a464dc07c0cfaf721a0916818d8 /tests/upgrade/src | |
parent | 7e08c172be8e584a30312d4b961c41df2eb17027 (diff) | |
download | sonarqube-d033213dad868cafabf6b8a63c17cf8c4f20c753.tar.gz sonarqube-d033213dad868cafabf6b8a63c17cf8c4f20c753.zip |
SONAR-7908 add integration test on ES + web nodes in cluster
Diffstat (limited to 'tests/upgrade/src')
-rw-r--r-- | tests/upgrade/src/test/java/org/sonarsource/sonarqube/upgrade/UpgradeTest.java | 44 |
1 files changed, 26 insertions, 18 deletions
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 dd9a803c7b1..bcc3d539ecc 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 @@ -19,8 +19,6 @@ */ package org.sonarsource.sonarqube.upgrade; -import static org.assertj.core.api.Assertions.assertThat; - import com.sonar.orchestrator.Orchestrator; import com.sonar.orchestrator.OrchestratorBuilder; import com.sonar.orchestrator.build.MavenBuild; @@ -42,6 +40,8 @@ import org.sonarqube.ws.client.WsClient; import org.sonarqube.ws.client.WsClientFactories; import org.sonarqube.ws.client.WsResponse; +import static org.assertj.core.api.Assertions.assertThat; + public class UpgradeTest { public static final String PROJECT_KEY = "org.apache.struts:struts-parent"; @@ -57,8 +57,8 @@ public class UpgradeTest { } @Test - public void test_upgrade_from_4_5_lts() { - testDatabaseUpgrade(Version.create("4.5.7"), "3.14"); + public void test_upgrade_from_5_6() { + testDatabaseUpgrade(Version.create("5.6.1"), "3.14"); } @Test @@ -67,18 +67,17 @@ public class UpgradeTest { } private void testDatabaseUpgrade(Version fromVersion, String javaVersion) { - startServer(fromVersion, javaVersion, false); + startOldServer(fromVersion, javaVersion); scanProject(); int files = countFiles(PROJECT_KEY); assertThat(files).isGreaterThan(0); - stopServer(); - // latest version - startServer(Version.create(Orchestrator.builderEnv().getSonarVersion()), "LATEST_RELEASE", true); + + startNewServer(); checkSystemStatus(ServerStatusResponse.Status.DB_MIGRATION_NEEDED); checkUrlsBeforeUpgrade(); - upgradeDatabase(); + upgrade(); checkSystemStatus(ServerStatusResponse.Status.UP); checkUrlsAfterUpgrade(); @@ -139,22 +138,31 @@ public class UpgradeTest { testUrl("/profiles"); } - private void upgradeDatabase() { + private void upgrade() { ServerMigrationResponse serverMigrationResponse = new ServerMigrationCall(orchestrator).callAndWait(); assertThat(serverMigrationResponse.getStatus()).isEqualTo(ServerMigrationResponse.Status.MIGRATION_SUCCEEDED); } - private void startServer(Version sqVersion, String javaVersion, boolean keepDatabase) { + private void startOldServer(Version sqVersion, String javaVersion) { String jdbcUrl = MssqlConfig.fixUrl(Configuration.createEnv(), sqVersion); - OrchestratorBuilder builder = Orchestrator.builderEnv() + orchestrator = Orchestrator.builderEnv() .setOrchestratorProperty("sonar.jdbc.url", jdbcUrl) - .setSonarVersion(sqVersion.toString()); - builder.setOrchestratorProperty("orchestrator.keepDatabase", String.valueOf(keepDatabase)); - if (!keepDatabase) { - builder.restoreProfileAtStartup(FileLocation.ofClasspath("/sonar-way-5.1.xml")); - } - builder.setOrchestratorProperty("javaVersion", javaVersion).addPlugin("java"); + .setSonarVersion(sqVersion.toString()) + .setOrchestratorProperty("orchestrator.keepDatabase", "false") + .restoreProfileAtStartup(FileLocation.ofClasspath("/sonar-way-5.1.xml")) + .setOrchestratorProperty("javaVersion", javaVersion) + .addPlugin("java").build(); + orchestrator.start(); + } + + private void startNewServer() { + OrchestratorBuilder builder = Orchestrator.builderEnv() + .setSonarVersion("DEV") + .setOrchestratorProperty("orchestrator.keepDatabase", "true") + .setOrchestratorProperty("javaVersion", "LATEST_RELEASE") + .setStartupLogWatcher(log -> log.contains("Process[web] is up")) + .addPlugin("java"); orchestrator = builder.build(); orchestrator.start(); } |