Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

#753: Add support for Sonarqube 10.0 #754

Merged
merged 1 commit into from
Sep 16, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ jobs:
fail-fast: false
matrix:
java:
- 11
- 17
steps:
-
name: Checkout
Expand All @@ -67,7 +67,7 @@ jobs:
./gradlew clean build
-
name: Archive artifact
if: success() && matrix.java == '11'
if: success() && matrix.java == '17'
uses: actions/upload-artifact@v3
with:
name: snapshot
Expand All @@ -87,7 +87,7 @@ jobs:
name: Set up Java
uses: actions/setup-java@v3
with:
java-version: 11
java-version: 17
java-package: jdk
distribution: 'zulu'
-
Expand Down Expand Up @@ -148,7 +148,7 @@ jobs:
name: Set up Java
uses: actions/setup-java@v3
with:
java-version: 11
java-version: 17
java-package: jdk
distribution: 'zulu'
-
Expand Down
7 changes: 7 additions & 0 deletions .github/workflows/codeql-analysis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,13 @@ jobs:
- name: Checkout repository
uses: actions/checkout@v3

- name: Set up Java
uses: actions/setup-java@v3
with:
java-version: 17
java-package: jdk
distribution: 'zulu'

- name: Initialize CodeQL
uses: github/codeql-action/init@v2
with:
Expand Down
6 changes: 3 additions & 3 deletions build.gradle
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2020-2022 Michael Clarke
* Copyright (C) 2020-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -40,7 +40,7 @@ repositories {
}
}

def sonarqubeVersion = '9.8.0.63668'
def sonarqubeVersion = '10.0.0.68432'
def sonarqubeLibDir = "${projectDir}/sonarqube-lib"
def sonarLibraries = "${sonarqubeLibDir}/sonarqube-${sonarqubeVersion}/lib"

Expand Down Expand Up @@ -100,7 +100,7 @@ jar {
'Plugin-License': 'GNU LGPL 3',
'Plugin-Version': "${project.version}",
'Plugin-Organization': 'Michael Clarke',
'Sonar-Version': "${sonarqubeVersion}",
'Sonar-Version': "9.14.0.375",
mc1arke marked this conversation as resolved.
Show resolved Hide resolved
'Plugin-IssueTrackerUrl': 'https://github.com/mc1arke/sonarqube-community-branch-plugin/issues',
'Plugin-Key': 'communityBranchPlugin',
'Plugin-Class': 'com.github.mc1arke.sonarqube.plugin.CommunityBranchPluginBootstrap',
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2021-2022 Michael Clarke
* Copyright (C) 2021-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -52,9 +52,9 @@ public static void premain(String args, Instrumentation instrumentation) throws

if (component == Component.CE) {
redefineEdition(instrumentation, "org.sonar.core.platform.PlatformEditionProvider", redefineOptionalEditionGetMethod());
redefineEdition(instrumentation, "org.sonar.server.almsettings.MultipleAlmFeature", redefineIsEnabledFlag());
redefineEdition(instrumentation, "org.sonar.server.almsettings.MultipleAlmFeature", redefineIsAvailableFlag());
} else if (component == Component.WEB) {
redefineEdition(instrumentation, "org.sonar.server.almsettings.MultipleAlmFeature", redefineIsEnabledFlag());
redefineEdition(instrumentation, "org.sonar.server.almsettings.MultipleAlmFeature", redefineIsAvailableFlag());
redefineEdition(instrumentation, "org.sonar.server.newcodeperiod.ws.SetAction", redefineConstructorEditionProviderField(EditionProvider.Edition.DEVELOPER));
redefineEdition(instrumentation, "org.sonar.server.newcodeperiod.ws.UnsetAction", redefineConstructorEditionProviderField(EditionProvider.Edition.DEVELOPER));
}
Expand Down Expand Up @@ -102,9 +102,9 @@ private static Redefiner redefineOptionalEditionGetMethod() {
};
}

private static Redefiner redefineIsEnabledFlag() {
private static Redefiner redefineIsAvailableFlag() {
return ctClass -> {
CtMethod ctMethod = ctClass.getDeclaredMethod("isEnabled");
CtMethod ctMethod = ctClass.getDeclaredMethod("isAvailable");
ctMethod.setBody("return true;");
};
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2020-2022 Michael Clarke
* Copyright (C) 2020-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand All @@ -18,8 +18,16 @@
*/
package com.github.mc1arke.sonarqube.plugin.scanner;

import java.util.Arrays;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import java.util.stream.Collectors;

import org.apache.commons.lang.StringUtils;
import org.sonar.api.notifications.AnalysisWarnings;
import org.sonar.api.utils.MessageException;
import org.sonar.api.utils.System2;
import org.sonar.api.utils.log.Logger;
Expand All @@ -30,15 +38,6 @@
import org.sonar.scanner.scan.branch.DefaultBranchConfiguration;
import org.sonar.scanner.scan.branch.ProjectBranches;

import java.util.Arrays;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import java.util.stream.Collectors;

/**
* @author Michael Clarke
*/
Expand All @@ -54,16 +53,13 @@ public class CommunityBranchConfigurationLoader implements BranchConfigurationLo
ScannerProperties.PULL_REQUEST_BASE));

private final System2 system2;
private final AnalysisWarnings analysisWarnings;
private final BranchConfigurationFactory branchConfigurationFactory;
private final List<BranchAutoConfigurer> autoConfigurers;

public CommunityBranchConfigurationLoader(System2 system2, AnalysisWarnings analysisWarnings,
BranchConfigurationFactory branchConfigurationFactory,
public CommunityBranchConfigurationLoader(System2 system2, BranchConfigurationFactory branchConfigurationFactory,
List<BranchAutoConfigurer> autoConfigurers) {
super();
this.system2 = system2;
this.analysisWarnings = analysisWarnings;
this.branchConfigurationFactory = branchConfigurationFactory;
this.autoConfigurers = autoConfigurers;
}
Expand Down Expand Up @@ -94,12 +90,6 @@ public BranchConfiguration load(Map<String, String> localSettings, ProjectBranch
}
}

if (null != localSettings.get(ScannerProperties.BRANCH_TARGET)) { //NOSONAR - purposefully checking for a deprecated parameter
String warning = String.format("Property '%s' is no longer supported", ScannerProperties.BRANCH_TARGET); //NOSONAR - reporting use of deprecated parameter
analysisWarnings.addUnique(warning);
LOGGER.warn(warning);
}

if (hasBranchParameters) {
String branch = StringUtils.trimToNull(localSettings.get(ScannerProperties.BRANCH_NAME));
return branchConfigurationFactory.createBranchConfiguration(branch, projectBranches);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2019-2022 Michael Clarke
* Copyright (C) 2019-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -33,7 +33,7 @@ public String getName() {
}

@Override
public boolean isEnabled() {
public boolean isAvailable() {
return true;
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2020-2022 Michael Clarke
* Copyright (C) 2020-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -94,10 +94,8 @@ public ComponentDto createBranchComponent(DbSession dbSession, BranchSupport.Com

ComponentDto componentDto = mainComponentDto.copy()
.setUuid(branchUuid)
.setRootUuid(branchUuid)
.setBranchUuid(branchUuid)
.setUuidPath(ComponentDto.UUID_PATH_OF_ROOT)
.setModuleUuidPath(ComponentDto.UUID_PATH_SEPARATOR + branchUuid + ComponentDto.UUID_PATH_SEPARATOR)
.setMainBranchProjectUuid(mainComponentDto.uuid())
.setCreatedAt(new Date(clock.millis()));
dbClient.componentDao().insert(dbSession, componentDto);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2022 Michael Clarke
* Copyright (C) 2022-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -32,7 +32,7 @@ public String getName() {
}

@Override
public boolean isEnabled() {
public boolean isAvailable() {
return true;
}
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2021-2022 Michael Clarke
* Copyright (C) 2021-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -76,7 +76,7 @@ void shouldRedefineMultipleAlmFeatureClassForWebLaunch() throws ReflectiveOperat
SonarRuntime sonarRuntime = mock(SonarRuntime.class);

SonarQubeFeature multipleAlmFeatureProvider = redefined.getConstructor(SonarRuntime.class).newInstance(sonarRuntime);
assertThat(multipleAlmFeatureProvider.isEnabled()).isTrue();
assertThat(multipleAlmFeatureProvider.isAvailable()).isTrue();
}
}

Expand Down Expand Up @@ -207,7 +207,7 @@ void shouldRedefineTargetClassesForCeLaunch() throws ReflectiveOperationExceptio

Class<MultipleAlmFeature> redefined = (Class<MultipleAlmFeature>) classLoader.loadClass(MultipleAlmFeature.class.getName(), result);
SonarQubeFeature multipleAlmFeatureProvider = redefined.getConstructor(SonarRuntime.class).newInstance(sonarRuntime);
assertThat(multipleAlmFeatureProvider.isEnabled()).isTrue();
assertThat(multipleAlmFeatureProvider.isAvailable()).isTrue();
}
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2020-2022 Michael Clarke
* Copyright (C) 2020-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -31,7 +31,6 @@
import java.util.Optional;

import org.junit.jupiter.api.Test;
import org.sonar.api.notifications.AnalysisWarnings;
import org.sonar.api.utils.System2;
import org.sonar.scanner.scan.branch.BranchConfiguration;
import org.sonar.scanner.scan.branch.BranchConfigurationLoader;
Expand All @@ -43,11 +42,10 @@
*/
class CommunityBranchConfigurationLoaderTest {

private final AnalysisWarnings analysisWarnings = mock(AnalysisWarnings.class);
private final System2 system2 = mock(System2.class);
private final BranchConfigurationFactory branchConfigurationFactory = mock(BranchConfigurationFactory.class);
private final BranchAutoConfigurer branchAutoConfigurer = mock(BranchAutoConfigurer.class);
private final BranchConfigurationLoader testCase = new CommunityBranchConfigurationLoader(system2, analysisWarnings, branchConfigurationFactory, List.of(branchAutoConfigurer));
private final BranchConfigurationLoader testCase = new CommunityBranchConfigurationLoader(system2, branchConfigurationFactory, List.of(branchAutoConfigurer));

@Test
void shouldReturnResultFromAutoConfigurerIfPresentAndNoParametersSpecified() {
Expand Down Expand Up @@ -87,7 +85,6 @@ void shouldCreateBranchConfigurationIfAnyBranchPropertiesSet() {
assertThat(actual).isSameAs(branchConfiguration);
verify(branchConfigurationFactory).createBranchConfiguration("branch", projectBranches);
verifyNoInteractions(branchAutoConfigurer);
verify(analysisWarnings).addUnique("Property 'sonar.branch.target' is no longer supported");
}

@Test
Expand All @@ -101,7 +98,6 @@ void shouldCreatePullConfigurationIfAnyPullRequestPropertiesSet() {
assertThat(actual).isSameAs(branchConfiguration);
verify(branchConfigurationFactory).createPullRequestConfiguration("key", "source", "target", projectBranches);
verifyNoInteractions(branchAutoConfigurer);
verifyNoInteractions(analysisWarnings);
}

@Test
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2019-2022 Michael Clarke
* Copyright (C) 2019-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -36,6 +36,6 @@ void shouldReturnNameThatFrontEndLooksFor() {

@Test
void shouldReturnEnabledForFeature() {
assertThat(underTest.isEnabled()).isTrue();
assertThat(underTest.isAvailable()).isTrue();
}
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2020-2022 Michael Clarke
* Copyright (C) 2020-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -154,9 +154,7 @@ void shouldCreateComponentAndBranchDtoIfValidationPasses(String branchName, Stri
when(componentDto.copy()).thenReturn(copyComponentDto);
when(copyComponentDto.setBranchUuid(any())).thenReturn(copyComponentDto);
when(copyComponentDto.setKey(any())).thenReturn(copyComponentDto);
when(copyComponentDto.setRootUuid(any())).thenReturn(copyComponentDto);
when(copyComponentDto.setUuidPath(any())).thenReturn(copyComponentDto);
when(copyComponentDto.setModuleUuidPath(any())).thenReturn(copyComponentDto);
when(copyComponentDto.setUuid(any())).thenReturn(copyComponentDto);
when(copyComponentDto.setMainBranchProjectUuid(any())).thenReturn(copyComponentDto);
when(copyComponentDto.setCreatedAt(any())).thenReturn(copyComponentDto);
Expand Down Expand Up @@ -187,9 +185,7 @@ void shouldCreateComponentAndBranchDtoIfValidationPasses(String branchName, Stri

verify(componentDao).insert(dbSession, copyComponentDto);
verify(copyComponentDto).setUuid("uuid0");
verify(copyComponentDto).setRootUuid("uuid0");
verify(copyComponentDto).setUuidPath(".");
verify(copyComponentDto).setModuleUuidPath(".uuid0.");
verify(copyComponentDto).setMainBranchProjectUuid("componentUuid");
verify(copyComponentDto).setCreatedAt(new Date(12345678901234L));

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2022 Michael Clarke
* Copyright (C) 2022-2023 Michael Clarke
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
Expand Down Expand Up @@ -33,7 +33,7 @@ void shouldMatchNameRequiredByFrontEnd() {

@Test
void shouldSetFeatureAsEnabled() {
assertThat(underTest.isEnabled()).isTrue();
assertThat(underTest.isAvailable()).isTrue();
}

}