From 35405872fd55acf6e8d89665c0f3aebb3457ac2f Mon Sep 17 00:00:00 2001 From: Matteo Mara Date: Wed, 11 Dec 2024 17:09:56 +0100 Subject: SONAR-23954 Fix calculation of the field installedVersionActive in the response of api/system/upgrades --- .../server/platform/ws/ActiveVersionEvaluator.java | 20 ++++++--- .../platform/ws/ActiveVersionEvaluatorTest.java | 49 +++++++++++++++++++--- 2 files changed, 59 insertions(+), 10 deletions(-) diff --git a/server/sonar-webserver-webapi/src/main/java/org/sonar/server/platform/ws/ActiveVersionEvaluator.java b/server/sonar-webserver-webapi/src/main/java/org/sonar/server/platform/ws/ActiveVersionEvaluator.java index fae0633163c..3499b284fed 100644 --- a/server/sonar-webserver-webapi/src/main/java/org/sonar/server/platform/ws/ActiveVersionEvaluator.java +++ b/server/sonar-webserver-webapi/src/main/java/org/sonar/server/platform/ws/ActiveVersionEvaluator.java @@ -86,11 +86,21 @@ public class ActiveVersionEvaluator { } private static Release findPreviousReleaseIgnoringPatch(SortedSet releases) { - Release refRelease = releases.last(); - List sublist = Lists.reverse(releases.stream().toList()); - for (Release release : sublist) { - if (compareWithoutPatchVersion(release.getVersion(), refRelease.getVersion()) < 0) { - return release; + if (!releases.isEmpty()) { + Release refRelease = releases.last(); + int patchesOfRefRelease = 0; + List sublist = Lists.reverse(releases.stream().toList()); + for (Release release : sublist) { + int versionComparison = compareWithoutPatchVersion(release.getVersion(), refRelease.getVersion()); + if (versionComparison < 0) { + return release; + } else if (versionComparison == 0) { + patchesOfRefRelease++; + } + } + // if all releases have the same version, return the last one + if (patchesOfRefRelease == releases.size()) { + return refRelease; } } throw new IllegalStateException("Unable to find previous release in releases"); diff --git a/server/sonar-webserver-webapi/src/test/java/org/sonar/server/platform/ws/ActiveVersionEvaluatorTest.java b/server/sonar-webserver-webapi/src/test/java/org/sonar/server/platform/ws/ActiveVersionEvaluatorTest.java index d6d507e6b28..394e5a35874 100644 --- a/server/sonar-webserver-webapi/src/test/java/org/sonar/server/platform/ws/ActiveVersionEvaluatorTest.java +++ b/server/sonar-webserver-webapi/src/test/java/org/sonar/server/platform/ws/ActiveVersionEvaluatorTest.java @@ -20,6 +20,7 @@ package org.sonar.server.platform.ws; import java.util.Calendar; +import java.util.Collections; import java.util.SortedSet; import java.util.TreeSet; import org.junit.jupiter.api.BeforeEach; @@ -106,12 +107,11 @@ class ActiveVersionEvaluatorTest { } @Test - void evaluateIfActiveVersion_whenNoPreviousReleasesFound_shouldThrowIllegalStateException() { + void evaluateIfActiveVersion_whenNoReleasesFound_shouldThrowIllegalStateException() { - when(sonarQubeVersion.get()).thenReturn(parse("10.4.1")); - TreeSet releases = new TreeSet<>(); - releases.add(new Release(sonar, Version.create("10.4.1"))); - when(sonar.getAllReleases(any())).thenReturn(releases); + when(sonarQubeVersion.get()).thenReturn(parse("10.8.0")); + + when(sonar.getAllReleases(any())).thenReturn(Collections.emptySortedSet()); assertThatThrownBy(() -> underTest.evaluateIfActiveVersion(updateCenter)) .isInstanceOf(IllegalStateException.class) @@ -134,6 +134,45 @@ class ActiveVersionEvaluatorTest { assertThat(underTest.evaluateIfActiveVersion(updateCenter)).isTrue(); } + @Test + void evaluateIfActiveVersion_whenInstalledVersionIsTheOnlyAvailableVersion_shouldReturnVersionIsActive() { + TreeSet releases = new TreeSet<>(); + releases.add(new Release(sonar, Version.create("10.8.0.12345"))); + + when(sonarQubeVersion.get()).thenReturn(parse("10.8.0.12345")); + when(updateCenter.getSonar().getAllReleases(any())).thenReturn(releases); + + assertThat(underTest.evaluateIfActiveVersion(updateCenter)).isTrue(); + } + + @Test + void evaluateIfActiveVersion_whenAvailableVersionsAreAllPatchesOfInstalledVersion_shouldReturnVersionIsActive() { + TreeSet releases = new TreeSet<>(); + releases.add(new Release(sonar, Version.create("10.8.0.12345"))); + releases.add(new Release(sonar, Version.create("10.8.1.12346"))); + when(sonar.getAllReleases(any())).thenReturn(releases); + + when(sonarQubeVersion.get()).thenReturn(parse("10.8.0.12345")); + when(updateCenter.getSonar().getAllReleases(any())).thenReturn(releases); + + assertThat(underTest.evaluateIfActiveVersion(updateCenter)).isTrue(); + } + + @Test + void evaluateIfActiveVersion_whenAvailableVersionsHaveDifferentNamingScheme_shouldReturnVersionIsActive() { + TreeSet releases = new TreeSet<>(); + releases.add(new Release(sonar, Version.create("10.8.0.12345"))); + releases.add(new Release(sonar, Version.create("10.8.1.12346"))); + releases.add(new Release(sonar, Version.create("2025.1.0.12347"))); + when(sonar.getAllReleases(any())).thenReturn(releases); + + when(sonarQubeVersion.get()).thenReturn(parse("10.8.0.12345")); + when(updateCenter.getSonar().getAllReleases(any())).thenReturn(releases); + + assertThat(underTest.evaluateIfActiveVersion(updateCenter)).isTrue(); + } + + public static SortedSet getReleases() { TreeSet releases = new TreeSet<>(); releases.add(new Release(sonar, Version.create("9.9"))); -- cgit v1.2.3