summaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
authorSébastien Lesaint <sebastien.lesaint@sonarsource.com>2015-05-04 17:35:58 +0200
committerSébastien Lesaint <sebastien.lesaint@sonarsource.com>2015-05-11 12:29:48 +0200
commit2e42d82b6033763f1d7bd410cd13f6c65b2cb094 (patch)
treef3902eb16594d2080bd15b86b3a8e549b2b4949f /server
parent9234f4d645764a01245ed27ee8da8a267a867c24 (diff)
downloadsonarqube-2e42d82b6033763f1d7bd410cd13f6c65b2cb094.tar.gz
sonarqube-2e42d82b6033763f1d7bd410cd13f6c65b2cb094.zip
SONAR-6365 implement DB check in /api/system/status
Diffstat (limited to 'server')
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/platform/ws/SystemStatusWsAction.java19
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/platform/ws/SystemStatusWsActionTest.java47
2 files changed, 62 insertions, 4 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/platform/ws/SystemStatusWsAction.java b/server/sonar-server/src/main/java/org/sonar/server/platform/ws/SystemStatusWsAction.java
index 6b4eadc3334..89e08b4dce5 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/platform/ws/SystemStatusWsAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/platform/ws/SystemStatusWsAction.java
@@ -23,7 +23,12 @@ import org.sonar.api.platform.Server;
import org.sonar.api.server.ws.Request;
import org.sonar.api.server.ws.Response;
import org.sonar.api.server.ws.WebService;
+import org.sonar.api.utils.log.Logger;
+import org.sonar.api.utils.log.Loggers;
import org.sonar.api.utils.text.JsonWriter;
+import org.sonar.core.persistence.DbSession;
+import org.sonar.core.persistence.IsAliveMapper;
+import org.sonar.server.db.DbClient;
import org.sonar.server.db.migrations.DatabaseMigration;
import org.sonar.server.platform.Platform;
@@ -34,14 +39,18 @@ import com.google.common.io.Resources;
*/
public class SystemStatusWsAction implements SystemWsAction {
+ private static final Logger LOGGER = Loggers.get(SystemStatusWsAction.class);
+
private final Server server;
private final DatabaseMigration databaseMigration;
private final Platform platform;
+ private final DbClient dbClient;
- public SystemStatusWsAction(Server server, DatabaseMigration databaseMigration, Platform platform) {
+ public SystemStatusWsAction(Server server, DatabaseMigration databaseMigration, Platform platform, DbClient dbClient) {
this.server = server;
this.databaseMigration = databaseMigration;
this.platform = platform;
+ this.dbClient = dbClient;
}
@Override
@@ -98,8 +107,12 @@ public class SystemStatusWsAction implements SystemWsAction {
}
private boolean isConnectedToDB() {
- // TODO check DB connection is up
- return true;
+ try (DbSession dbSession = dbClient.openSession(false)) {
+ return dbSession.getMapper(IsAliveMapper.class).isAlive() == IsAliveMapper.IS_ALIVE_RETURNED_VALUE;
+ } catch (RuntimeException e) {
+ LOGGER.error("DB connection is down", e);
+ return false;
+ }
}
private Status computeFromDbMigrationStatus() {
diff --git a/server/sonar-server/src/test/java/org/sonar/server/platform/ws/SystemStatusWsActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/platform/ws/SystemStatusWsActionTest.java
index 2abcce7797e..ddcdaa9f9bd 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/platform/ws/SystemStatusWsActionTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/platform/ws/SystemStatusWsActionTest.java
@@ -22,10 +22,14 @@ package org.sonar.server.platform.ws;
import java.io.File;
import java.util.Date;
import java.util.Set;
+import org.junit.Before;
import org.junit.Test;
import org.sonar.api.platform.Server;
import org.sonar.api.server.ws.Request;
import org.sonar.api.server.ws.WebService;
+import org.sonar.core.persistence.DbSession;
+import org.sonar.core.persistence.IsAliveMapper;
+import org.sonar.server.db.DbClient;
import org.sonar.server.db.migrations.DatabaseMigration;
import org.sonar.server.platform.Platform;
import org.sonar.server.ws.WsTester;
@@ -36,6 +40,7 @@ import static com.google.common.collect.ImmutableSet.of;
import static com.google.common.collect.Iterables.filter;
import static java.util.Arrays.asList;
import static org.assertj.core.api.Assertions.assertThat;
+import static org.mockito.Matchers.anyBoolean;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import static org.sonar.test.JsonAssert.assertJson;
@@ -56,8 +61,18 @@ public class SystemStatusWsActionTest {
private static Server server = new Dummy51Server();
private DatabaseMigration databaseMigration = mock(DatabaseMigration.class);
private Platform platform = mock(Platform.class);
+ private DbClient dbClient = mock(DbClient.class);
+ private DbSession dbSession = mock(DbSession.class);
+ private IsAliveMapper isAliveMapper = mock(IsAliveMapper.class);
+ private SystemStatusWsAction underTest = new SystemStatusWsAction(server, databaseMigration, platform, dbClient);
+
private Request request = mock(Request.class);
- private SystemStatusWsAction underTest = new SystemStatusWsAction(server, databaseMigration, platform);
+
+ @Before
+ public void wireMocks() throws Exception {
+ when(dbClient.openSession(anyBoolean())).thenReturn(dbSession);
+ when(dbSession.getMapper(IsAliveMapper.class)).thenReturn(isAliveMapper);
+ }
@Test
public void action_status_is_defined() throws Exception {
@@ -80,6 +95,7 @@ public class SystemStatusWsActionTest {
@Test
public void verify_example() throws Exception {
+ when(isAliveMapper.isAlive()).thenReturn(IsAliveMapper.IS_ALIVE_RETURNED_VALUE);
when(platform.status()).thenReturn(Platform.Status.UP);
WsTester.TestResponse response = new WsTester.TestResponse();
@@ -123,6 +139,34 @@ public class SystemStatusWsActionTest {
}
@Test
+ public void status_is_DOWN_if_any_error_occurs_when_checking_DB() throws Exception {
+ when(isAliveMapper.isAlive()).thenThrow(new RuntimeException("simulated runtime exception when querying DB"));
+
+ WsTester.TestResponse response = new WsTester.TestResponse();
+ underTest.handle(request, response);
+
+ assertJson(response.outputAsString()).isSimilarTo("{" +
+ " \"status\": \"DOWN\"\n" +
+ "}");
+ }
+
+ /**
+ * By contract {@link IsAliveMapper#isAlive()} can not return anything but 1. Still we write this test as a
+ * protection against change in this contract.
+ */
+ @Test
+ public void status_is_DOWN_if_isAlive_does_not_return_1() throws Exception {
+ when(isAliveMapper.isAlive()).thenReturn(12);
+
+ WsTester.TestResponse response = new WsTester.TestResponse();
+ underTest.handle(request, response);
+
+ assertJson(response.outputAsString()).isSimilarTo("{" +
+ " \"status\": \"" + STATUS_DOWN + "\"\n" +
+ "}");
+ }
+
+ @Test
public void safety_test_for_new_platform_status() throws Exception {
for (Platform.Status platformStatus : filter(asList(Platform.Status.values()), not(in(SUPPORTED_PLATFORM_STATUSES)))) {
for (DatabaseMigration.Status databaseMigrationStatus : DatabaseMigration.Status.values()) {
@@ -143,6 +187,7 @@ public class SystemStatusWsActionTest {
}
private void verifyStatus(Platform.Status platformStatus, DatabaseMigration.Status databaseMigrationStatus, String expectedStatus) throws Exception {
+ when(isAliveMapper.isAlive()).thenReturn(IsAliveMapper.IS_ALIVE_RETURNED_VALUE);
when(platform.status()).thenReturn(platformStatus);
when(databaseMigration.status()).thenReturn(databaseMigrationStatus);