From e04d2b354591a5e19fa6ae2e489abcd7f2712547 Mon Sep 17 00:00:00 2001 From: lukasz-jarocki-sonarsource <77498856+lukasz-jarocki-sonarsource@users.noreply.github.com> Date: Thu, 3 Feb 2022 10:35:15 +0100 Subject: Added monitoring and telemetry to SonarLint push feature. (#5315) * SONAR-15921 add number of connected sonarlint clients to telemetry --- .../org/sonar/server/telemetry/TelemetryData.java | 12 +++ .../telemetry/TelemetryDataJsonWriterTest.java | 1 + server/sonar-webserver-core/build.gradle | 1 + .../server/platform/SystemInfoWriterModule.java | 2 + .../monitoring/cluster/ServerPushSection.java | 45 +++++++++ .../server/telemetry/TelemetryDataLoaderImpl.java | 6 +- .../platform/SystemInfoWriterModuleTest.java | 4 +- .../platform/monitoring/ServerPushSectionTest.java | 50 ++++++++++ .../telemetry/TelemetryDataLoaderImplTest.java | 3 +- server/sonar-webserver-monitoring/build.gradle | 1 + .../server/monitoring/ServerMonitoringMetrics.java | 11 +++ .../monitoring/SonarLintConnectedClientsTask.java | 55 +++++++++++ .../monitoring/ServerMonitoringMetricsTest.java | 10 ++ .../SonarLintConnectedClientsTaskTest.java | 106 +++++++++++++++++++++ .../sonarlint/SonarLintClientsRegistry.java | 6 +- .../sonarlint/SonarLintClientsRegistryTest.java | 6 +- .../platform/platformlevel/PlatformLevel4.java | 2 + 17 files changed, 308 insertions(+), 13 deletions(-) create mode 100644 server/sonar-webserver-core/src/main/java/org/sonar/server/platform/monitoring/cluster/ServerPushSection.java create mode 100644 server/sonar-webserver-core/src/test/java/org/sonar/server/platform/monitoring/ServerPushSectionTest.java create mode 100644 server/sonar-webserver-monitoring/src/main/java/org/sonar/server/monitoring/SonarLintConnectedClientsTask.java create mode 100644 server/sonar-webserver-monitoring/src/test/java/org/sonar/server/monitoring/SonarLintConnectedClientsTaskTest.java diff --git a/server/sonar-server-common/src/main/java/org/sonar/server/telemetry/TelemetryData.java b/server/sonar-server-common/src/main/java/org/sonar/server/telemetry/TelemetryData.java index 3f6d947a20a..89d5f724130 100644 --- a/server/sonar-server-common/src/main/java/org/sonar/server/telemetry/TelemetryData.java +++ b/server/sonar-server-common/src/main/java/org/sonar/server/telemetry/TelemetryData.java @@ -54,6 +54,7 @@ public class TelemetryData { private final Boolean hasUnanalyzedCpp; private final List customSecurityConfigs; private final long sonarlintWeeklyUsers; + private final long numberOfConnectedSonarLintClients; private TelemetryData(Builder builder) { serverId = builder.serverId; @@ -79,6 +80,7 @@ public class TelemetryData { externalAuthenticationProviders = builder.externalAuthenticationProviders; projectCountByScm = builder.projectCountByScm; projectCountByCi = builder.projectCountByCi; + numberOfConnectedSonarLintClients = builder.numberOfConnectedSonarLintClients; } public String getServerId() { @@ -101,6 +103,10 @@ public class TelemetryData { return sonarlintWeeklyUsers; } + public long sonarLintConnectedClients() { + return numberOfConnectedSonarLintClients; + } + public long getUserCount() { return userCount; } @@ -199,6 +205,7 @@ public class TelemetryData { private List externalAuthenticationProviders; private Map projectCountByScm; private Map projectCountByCi; + private long numberOfConnectedSonarLintClients; private Builder() { // enforce static factory method @@ -309,6 +316,11 @@ public class TelemetryData { return this; } + Builder setNumberOfConnectedSonarLintClients(long numberOfConnectedSonarLintClients) { + this.numberOfConnectedSonarLintClients = numberOfConnectedSonarLintClients; + return this; + } + TelemetryData build() { requireNonNull(serverId); requireNonNull(version); diff --git a/server/sonar-server-common/src/test/java/org/sonar/server/telemetry/TelemetryDataJsonWriterTest.java b/server/sonar-server-common/src/test/java/org/sonar/server/telemetry/TelemetryDataJsonWriterTest.java index 807625a31c1..aa280713ec1 100644 --- a/server/sonar-server-common/src/test/java/org/sonar/server/telemetry/TelemetryDataJsonWriterTest.java +++ b/server/sonar-server-common/src/test/java/org/sonar/server/telemetry/TelemetryDataJsonWriterTest.java @@ -60,6 +60,7 @@ public class TelemetryDataJsonWriterTest { .setExternalAuthenticationProviders(asList("github", "gitlab")) .setProjectCountByScm(Collections.emptyMap()) .setSonarlintWeeklyUsers(10) + .setNumberOfConnectedSonarLintClients(5) .setProjectCountByCi(Collections.emptyMap()) .setDatabase(new TelemetryData.Database("H2", "11")) .setUsingBranches(true); diff --git a/server/sonar-webserver-core/build.gradle b/server/sonar-webserver-core/build.gradle index 7b9f8fc6c6b..9aba24d6f0c 100644 --- a/server/sonar-webserver-core/build.gradle +++ b/server/sonar-webserver-core/build.gradle @@ -42,6 +42,7 @@ dependencies { compile project(':server:sonar-process') compile project(':server:sonar-server-common') compile project(':server:sonar-webserver-api') + compile project(':server:sonar-webserver-pushapi') compile project(':server:sonar-webserver-es') compile project(':sonar-core') compile project(':sonar-duplications') diff --git a/server/sonar-webserver-core/src/main/java/org/sonar/server/platform/SystemInfoWriterModule.java b/server/sonar-webserver-core/src/main/java/org/sonar/server/platform/SystemInfoWriterModule.java index 73ec7490ac5..c0602d1315e 100644 --- a/server/sonar-webserver-core/src/main/java/org/sonar/server/platform/SystemInfoWriterModule.java +++ b/server/sonar-webserver-core/src/main/java/org/sonar/server/platform/SystemInfoWriterModule.java @@ -37,6 +37,7 @@ import org.sonar.server.platform.monitoring.cluster.CeQueueGlobalSection; import org.sonar.server.platform.monitoring.cluster.EsClusterStateSection; import org.sonar.server.platform.monitoring.cluster.GlobalInfoLoader; import org.sonar.server.platform.monitoring.cluster.GlobalSystemSection; +import org.sonar.server.platform.monitoring.cluster.ServerPushSection; import org.sonar.server.platform.monitoring.cluster.NodeSystemSection; import org.sonar.server.platform.monitoring.cluster.ProcessInfoProvider; import org.sonar.server.platform.monitoring.cluster.SearchNodesInfoLoaderImpl; @@ -62,6 +63,7 @@ public class SystemInfoWriterModule extends Module { PluginsSection.class, SettingsSection.class, AlmConfigurationSection.class, + ServerPushSection.class, BundledSection.class ); diff --git a/server/sonar-webserver-core/src/main/java/org/sonar/server/platform/monitoring/cluster/ServerPushSection.java b/server/sonar-webserver-core/src/main/java/org/sonar/server/platform/monitoring/cluster/ServerPushSection.java new file mode 100644 index 00000000000..fe94bf7d9aa --- /dev/null +++ b/server/sonar-webserver-core/src/main/java/org/sonar/server/platform/monitoring/cluster/ServerPushSection.java @@ -0,0 +1,45 @@ +/* + * SonarQube + * Copyright (C) 2009-2021 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.server.platform.monitoring.cluster; + +import org.sonar.api.server.ServerSide; +import org.sonar.process.systeminfo.SystemInfoSection; +import org.sonar.process.systeminfo.protobuf.ProtobufSystemInfo; +import org.sonar.server.pushapi.sonarlint.SonarLintClientsRegistry; + +import static org.sonar.process.systeminfo.SystemInfoUtils.setAttribute; + +@ServerSide +public class ServerPushSection implements SystemInfoSection { + + private final SonarLintClientsRegistry sonarLintClientsRegistry; + + public ServerPushSection(SonarLintClientsRegistry sonarLintClientsRegistry) { + this.sonarLintClientsRegistry = sonarLintClientsRegistry; + } + + @Override + public ProtobufSystemInfo.Section toProtobuf() { + ProtobufSystemInfo.Section.Builder protobuf = ProtobufSystemInfo.Section.newBuilder(); + protobuf.setName("Server Push Connections"); + setAttribute(protobuf, "SonarLint Connected Clients", sonarLintClientsRegistry.countConnectedClients()); + return protobuf.build(); + } +} diff --git a/server/sonar-webserver-core/src/main/java/org/sonar/server/telemetry/TelemetryDataLoaderImpl.java b/server/sonar-webserver-core/src/main/java/org/sonar/server/telemetry/TelemetryDataLoaderImpl.java index d3813e8150a..ab9ec5daaa6 100644 --- a/server/sonar-webserver-core/src/main/java/org/sonar/server/telemetry/TelemetryDataLoaderImpl.java +++ b/server/sonar-webserver-core/src/main/java/org/sonar/server/telemetry/TelemetryDataLoaderImpl.java @@ -76,13 +76,13 @@ public class TelemetryDataLoaderImpl implements TelemetryDataLoader { private final LicenseReader licenseReader; public TelemetryDataLoaderImpl(Server server, DbClient dbClient, PluginRepository pluginRepository, UserIndex userIndex, ProjectMeasuresIndex projectMeasuresIndex, - PlatformEditionProvider editionProvider, InternalProperties internalProperties, Configuration configuration, DockerSupport dockerSupport) { + PlatformEditionProvider editionProvider, InternalProperties internalProperties, Configuration configuration, DockerSupport dockerSupport) { this(server, dbClient, pluginRepository, userIndex, projectMeasuresIndex, editionProvider, internalProperties, configuration, dockerSupport, null); } public TelemetryDataLoaderImpl(Server server, DbClient dbClient, PluginRepository pluginRepository, UserIndex userIndex, ProjectMeasuresIndex projectMeasuresIndex, - PlatformEditionProvider editionProvider, InternalProperties internalProperties, Configuration configuration, - DockerSupport dockerSupport, @Nullable LicenseReader licenseReader) { + PlatformEditionProvider editionProvider, InternalProperties internalProperties, Configuration configuration, + DockerSupport dockerSupport, @Nullable LicenseReader licenseReader) { this.server = server; this.dbClient = dbClient; this.pluginRepository = pluginRepository; diff --git a/server/sonar-webserver-core/src/test/java/org/sonar/server/platform/SystemInfoWriterModuleTest.java b/server/sonar-webserver-core/src/test/java/org/sonar/server/platform/SystemInfoWriterModuleTest.java index 323c4eb3403..1d586a9ac43 100644 --- a/server/sonar-webserver-core/src/test/java/org/sonar/server/platform/SystemInfoWriterModuleTest.java +++ b/server/sonar-webserver-core/src/test/java/org/sonar/server/platform/SystemInfoWriterModuleTest.java @@ -42,7 +42,7 @@ public class SystemInfoWriterModuleTest { Collection> adapters = container.getPicoContainer().getComponentAdapters(); assertThat(adapters) - .hasSize(COMPONENTS_IN_EMPTY_COMPONENT_CONTAINER + 19); + .hasSize(COMPONENTS_IN_EMPTY_COMPONENT_CONTAINER + 20); } @Test @@ -54,7 +54,7 @@ public class SystemInfoWriterModuleTest { Collection> adapters = container.getPicoContainer().getComponentAdapters(); assertThat(adapters) - .hasSize(COMPONENTS_IN_EMPTY_COMPONENT_CONTAINER + 13); + .hasSize(COMPONENTS_IN_EMPTY_COMPONENT_CONTAINER + 14); } } diff --git a/server/sonar-webserver-core/src/test/java/org/sonar/server/platform/monitoring/ServerPushSectionTest.java b/server/sonar-webserver-core/src/test/java/org/sonar/server/platform/monitoring/ServerPushSectionTest.java new file mode 100644 index 00000000000..1d3b61d820a --- /dev/null +++ b/server/sonar-webserver-core/src/test/java/org/sonar/server/platform/monitoring/ServerPushSectionTest.java @@ -0,0 +1,50 @@ +/* + * SonarQube + * Copyright (C) 2009-2021 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.server.platform.monitoring; + +import org.junit.Test; +import org.sonar.process.systeminfo.protobuf.ProtobufSystemInfo; +import org.sonar.server.platform.monitoring.cluster.ServerPushSection; +import org.sonar.server.pushapi.sonarlint.SonarLintClientsRegistry; + +import static org.assertj.core.api.Assertions.assertThat; +import static org.assertj.core.api.Assertions.tuple; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.when; + +public class ServerPushSectionTest { + + private final SonarLintClientsRegistry sonarLintClientsRegistry = mock(SonarLintClientsRegistry.class); + + private final ServerPushSection underTest = new ServerPushSection(sonarLintClientsRegistry); + + @Test + public void toProtobuf_with5ConnectedSonarLintClients() { + + when(sonarLintClientsRegistry.countConnectedClients()).thenReturn(5L); + + ProtobufSystemInfo.Section section = underTest.toProtobuf(); + + assertThat(section.getName()).isEqualTo("Server Push Connections"); + assertThat(section.getAttributesList()) + .extracting(ProtobufSystemInfo.Attribute::getKey, ProtobufSystemInfo.Attribute::getLongValue) + .containsExactlyInAnyOrder(tuple("SonarLint Connected Clients", 5L)); + } +} diff --git a/server/sonar-webserver-core/src/test/java/org/sonar/server/telemetry/TelemetryDataLoaderImplTest.java b/server/sonar-webserver-core/src/test/java/org/sonar/server/telemetry/TelemetryDataLoaderImplTest.java index 1d3fac27fe6..0ba187b2971 100644 --- a/server/sonar-webserver-core/src/test/java/org/sonar/server/telemetry/TelemetryDataLoaderImplTest.java +++ b/server/sonar-webserver-core/src/test/java/org/sonar/server/telemetry/TelemetryDataLoaderImplTest.java @@ -41,6 +41,7 @@ import org.sonar.server.measure.index.ProjectMeasuresIndexer; import org.sonar.server.platform.DockerSupport; import org.sonar.server.property.InternalProperties; import org.sonar.server.property.MapInternalProperties; +import org.sonar.server.pushapi.sonarlint.SonarLintClientsRegistry; import org.sonar.server.user.index.UserIndex; import org.sonar.server.user.index.UserIndexer; import org.sonar.updatecenter.common.Version; @@ -85,7 +86,7 @@ public class TelemetryDataLoaderImplTest { private final LicenseReader licenseReader = mock(LicenseReader.class); private final TelemetryDataLoader communityUnderTest = new TelemetryDataLoaderImpl(server, db.getDbClient(), pluginRepository, new UserIndex(es.client(), system2), - new ProjectMeasuresIndex(es.client(), null, system2), editionProvider, internalProperties, configuration, dockerSupport, null); + new ProjectMeasuresIndex(es.client(), null, system2), editionProvider, internalProperties, configuration, dockerSupport); private final TelemetryDataLoader commercialUnderTest = new TelemetryDataLoaderImpl(server, db.getDbClient(), pluginRepository, new UserIndex(es.client(), system2), new ProjectMeasuresIndex(es.client(), null, system2), editionProvider, internalProperties, configuration, dockerSupport, licenseReader); diff --git a/server/sonar-webserver-monitoring/build.gradle b/server/sonar-webserver-monitoring/build.gradle index 3f84d115f8d..45541df8947 100644 --- a/server/sonar-webserver-monitoring/build.gradle +++ b/server/sonar-webserver-monitoring/build.gradle @@ -3,6 +3,7 @@ description = 'SonarQube :: Monitoring' dependencies { compile project(path: ':sonar-plugin-api', configuration: 'shadow') compile project(':server:sonar-webserver-api') + compile project(':server:sonar-webserver-pushapi') compile project(':server:sonar-alm-client') compile 'io.prometheus:simpleclient' diff --git a/server/sonar-webserver-monitoring/src/main/java/org/sonar/server/monitoring/ServerMonitoringMetrics.java b/server/sonar-webserver-monitoring/src/main/java/org/sonar/server/monitoring/ServerMonitoringMetrics.java index afa858d4533..e01cd37de66 100644 --- a/server/sonar-webserver-monitoring/src/main/java/org/sonar/server/monitoring/ServerMonitoringMetrics.java +++ b/server/sonar-webserver-monitoring/src/main/java/org/sonar/server/monitoring/ServerMonitoringMetrics.java @@ -46,6 +46,8 @@ public class ServerMonitoringMetrics { private final Gauge webUptimeMinutes; + private final Gauge numberOfConnectedSonarLintClients; + public ServerMonitoringMetrics() { githubHealthIntegrationStatus = Gauge.build() .name("sonarqube_health_integration_github_status") @@ -120,6 +122,11 @@ public class ServerMonitoringMetrics { .help("Number of minutes for how long the SonarQube instance is running") .register(); + numberOfConnectedSonarLintClients = Gauge.build() + .name("sonarqube_number_of_connected_sonarlint_clients") + .help("Number of connected SonarLint clients") + .register(); + } public void setGithubStatusToGreen() { @@ -201,4 +208,8 @@ public class ServerMonitoringMetrics { public void setWebUptimeMinutes(long minutes) { webUptimeMinutes.set(minutes); } + + public void setNumberOfConnectedSonarLintClients(long noOfClients) { + numberOfConnectedSonarLintClients.set(noOfClients); + } } diff --git a/server/sonar-webserver-monitoring/src/main/java/org/sonar/server/monitoring/SonarLintConnectedClientsTask.java b/server/sonar-webserver-monitoring/src/main/java/org/sonar/server/monitoring/SonarLintConnectedClientsTask.java new file mode 100644 index 00000000000..3a982924bf9 --- /dev/null +++ b/server/sonar-webserver-monitoring/src/main/java/org/sonar/server/monitoring/SonarLintConnectedClientsTask.java @@ -0,0 +1,55 @@ +/* + * SonarQube + * Copyright (C) 2009-2021 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.server.monitoring; + +import org.sonar.api.config.Configuration; +import org.sonar.server.pushapi.sonarlint.SonarLintClientsRegistry; + +public class SonarLintConnectedClientsTask implements MonitoringTask { + + private static final String DELAY_IN_MILISECONDS_PROPERTY = "sonar.server.monitoring.other.initial.delay"; + private static final String PERIOD_IN_MILISECONDS_PROPERTY = "sonar.server.monitoring.other.period"; + + private final ServerMonitoringMetrics serverMonitoringMetrics; + private final SonarLintClientsRegistry sonarLintClientsRegistry; + private final Configuration config; + + public SonarLintConnectedClientsTask(ServerMonitoringMetrics serverMonitoringMetrics, SonarLintClientsRegistry sonarLintClientsRegistry, + Configuration configuration) { + this.serverMonitoringMetrics = serverMonitoringMetrics; + this.sonarLintClientsRegistry = sonarLintClientsRegistry; + this.config = configuration; + } + + @Override + public void run() { + serverMonitoringMetrics.setNumberOfConnectedSonarLintClients(sonarLintClientsRegistry.countConnectedClients()); + } + + @Override + public long getDelay() { + return config.getLong(DELAY_IN_MILISECONDS_PROPERTY).orElse(10_000L); + } + + @Override + public long getPeriod() { + return config.getLong(PERIOD_IN_MILISECONDS_PROPERTY).orElse(10_000L); + } +} diff --git a/server/sonar-webserver-monitoring/src/test/java/org/sonar/server/monitoring/ServerMonitoringMetricsTest.java b/server/sonar-webserver-monitoring/src/test/java/org/sonar/server/monitoring/ServerMonitoringMetricsTest.java index 83c324313db..338d097d52b 100644 --- a/server/sonar-webserver-monitoring/src/test/java/org/sonar/server/monitoring/ServerMonitoringMetricsTest.java +++ b/server/sonar-webserver-monitoring/src/test/java/org/sonar/server/monitoring/ServerMonitoringMetricsTest.java @@ -119,6 +119,16 @@ public class ServerMonitoringMetricsTest { .isEqualTo(10); } + @Test + public void setters_setNumberOfConnectedSonarLintClients() { + ServerMonitoringMetrics metrics = new ServerMonitoringMetrics(); + + metrics.setNumberOfConnectedSonarLintClients(5); + + assertThat(CollectorRegistry.defaultRegistry.getSampleValue("sonarqube_number_of_connected_sonarlint_clients")) + .isEqualTo(5); + } + @Test public void setters_setElasticsearchMetricsWithLabels() { ServerMonitoringMetrics metrics = new ServerMonitoringMetrics(); diff --git a/server/sonar-webserver-monitoring/src/test/java/org/sonar/server/monitoring/SonarLintConnectedClientsTaskTest.java b/server/sonar-webserver-monitoring/src/test/java/org/sonar/server/monitoring/SonarLintConnectedClientsTaskTest.java new file mode 100644 index 00000000000..a6a0250dd13 --- /dev/null +++ b/server/sonar-webserver-monitoring/src/test/java/org/sonar/server/monitoring/SonarLintConnectedClientsTaskTest.java @@ -0,0 +1,106 @@ +/* + * SonarQube + * Copyright (C) 2009-2021 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.server.monitoring; + +import java.util.HashMap; +import java.util.Map; +import java.util.Optional; +import org.junit.Test; +import org.sonar.api.config.Configuration; +import org.sonar.server.pushapi.sonarlint.SonarLintClientsRegistry; + +import static org.assertj.core.api.Assertions.assertThat; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.verify; +import static org.mockito.Mockito.when; + +public class SonarLintConnectedClientsTaskTest { + + private final ServerMonitoringMetrics metrics = mock(ServerMonitoringMetrics.class); + private final SonarLintClientsRegistry sonarLintClientsRegistry = mock(SonarLintClientsRegistry.class); + private final SonarLintConnectedClientsTaskTest.DumpMapConfiguration config = new SonarLintConnectedClientsTaskTest.DumpMapConfiguration(); + private final SonarLintConnectedClientsTask underTest = new SonarLintConnectedClientsTask(metrics, sonarLintClientsRegistry, config); + + @Test + public void run_when5ConnectedClients_updateWith5() { + when(sonarLintClientsRegistry.countConnectedClients()).thenReturn(5L); + + underTest.run(); + + verify(metrics).setNumberOfConnectedSonarLintClients(5L); + } + + @Test + public void getDelay_returnNumberIfConfigEmpty() { + long delay = underTest.getDelay(); + + assertThat(delay).isPositive(); + } + + @Test + public void getDelay_returnNumberFromConfig() { + config.put("sonar.server.monitoring.other.initial.delay", "100000"); + + long delay = underTest.getDelay(); + + assertThat(delay).isEqualTo(100_000L); + } + + @Test + public void getPeriod_returnNumberIfConfigEmpty() { + long delay = underTest.getPeriod(); + + assertThat(delay).isPositive(); + } + + @Test + public void getPeriod_returnNumberFromConfig() { + config.put("sonar.server.monitoring.other.period", "100000"); + + long delay = underTest.getPeriod(); + + assertThat(delay).isEqualTo(100_000L); + } + + private static class DumpMapConfiguration implements Configuration { + private final Map keyValues = new HashMap<>(); + + public Configuration put(String key, String value) { + keyValues.put(key, value.trim()); + return this; + } + + @Override + public Optional get(String key) { + return Optional.ofNullable(keyValues.get(key)); + } + + @Override + public boolean hasKey(String key) { + throw new UnsupportedOperationException("hasKey not implemented"); + } + + @Override + public String[] getStringArray(String key) { + throw new UnsupportedOperationException("getStringArray not implemented"); + } + } + +} diff --git a/server/sonar-webserver-pushapi/src/main/java/org/sonar/server/pushapi/sonarlint/SonarLintClientsRegistry.java b/server/sonar-webserver-pushapi/src/main/java/org/sonar/server/pushapi/sonarlint/SonarLintClientsRegistry.java index 44d9fa4917d..b3319ddc579 100644 --- a/server/sonar-webserver-pushapi/src/main/java/org/sonar/server/pushapi/sonarlint/SonarLintClientsRegistry.java +++ b/server/sonar-webserver-pushapi/src/main/java/org/sonar/server/pushapi/sonarlint/SonarLintClientsRegistry.java @@ -19,7 +19,6 @@ */ package org.sonar.server.pushapi.sonarlint; -import com.google.common.annotations.VisibleForTesting; import java.util.List; import java.util.concurrent.CopyOnWriteArrayList; import javax.servlet.AsyncEvent; @@ -47,9 +46,8 @@ public class SonarLintClientsRegistry { LOG.debug("Removing SonarLint client"); } - @VisibleForTesting - List getAllClients() { - return clients; + public long countConnectedClients() { + return clients.size(); } class SonarLintClientEventsListener implements AsyncListener { diff --git a/server/sonar-webserver-pushapi/src/test/java/org/sonar/server/pushapi/sonarlint/SonarLintClientsRegistryTest.java b/server/sonar-webserver-pushapi/src/test/java/org/sonar/server/pushapi/sonarlint/SonarLintClientsRegistryTest.java index f6f0ccd68f7..a70886166ea 100644 --- a/server/sonar-webserver-pushapi/src/test/java/org/sonar/server/pushapi/sonarlint/SonarLintClientsRegistryTest.java +++ b/server/sonar-webserver-pushapi/src/test/java/org/sonar/server/pushapi/sonarlint/SonarLintClientsRegistryTest.java @@ -48,11 +48,11 @@ public class SonarLintClientsRegistryTest { underTest.registerClient(sonarLintClient); - assertThat(underTest.getAllClients()).hasSize(1); + assertThat(underTest.countConnectedClients()).isEqualTo(1); underTest.unregisterClient(sonarLintClient); - assertThat(underTest.getAllClients()).isEmpty(); + assertThat(underTest.countConnectedClients()).isZero(); } @Test @@ -63,7 +63,7 @@ public class SonarLintClientsRegistryTest { underTest.registerClient(sonarLintClient); } - assertThat(underTest.getAllClients()).hasSize(10); + assertThat(underTest.countConnectedClients()).isEqualTo(10); } } diff --git a/server/sonar-webserver/src/main/java/org/sonar/server/platform/platformlevel/PlatformLevel4.java b/server/sonar-webserver/src/main/java/org/sonar/server/platform/platformlevel/PlatformLevel4.java index 5937ac9295f..f5c1bde9d9b 100644 --- a/server/sonar-webserver/src/main/java/org/sonar/server/platform/platformlevel/PlatformLevel4.java +++ b/server/sonar-webserver/src/main/java/org/sonar/server/platform/platformlevel/PlatformLevel4.java @@ -131,6 +131,7 @@ import org.sonar.server.monitoring.ElasticSearchMetricTask; import org.sonar.server.monitoring.MainCollector; import org.sonar.server.monitoring.MonitoringWsModule; import org.sonar.server.monitoring.ServerMonitoringMetrics; +import org.sonar.server.monitoring.SonarLintConnectedClientsTask; import org.sonar.server.monitoring.WebUptimeTask; import org.sonar.server.monitoring.ce.NumberOfTasksInQueueTask; import org.sonar.server.monitoring.ce.RecentTasksDurationTask; @@ -603,6 +604,7 @@ public class PlatformLevel4 extends PlatformLevel { ComputeEngineMetricStatusTask.class, ElasticSearchMetricTask.class, WebUptimeTask.class, + SonarLintConnectedClientsTask.class, MainCollector.class, -- cgit v1.2.3