-
Notifications
You must be signed in to change notification settings - Fork 152
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(pitest): Add UpgradeAction for pitest settings
- Loading branch information
1 parent
93698ac
commit 7a822e2
Showing
11 changed files
with
520 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
132 changes: 132 additions & 0 deletions
132
src/main/java/co/com/bancolombia/factory/upgrades/actions/UpgradeY2024M10D17AddPitest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,132 @@ | ||
package co.com.bancolombia.factory.upgrades.actions; | ||
|
||
import static co.com.bancolombia.Constants.MainFiles.BUILD_GRADLE; | ||
import static co.com.bancolombia.Constants.MainFiles.MAIN_GRADLE; | ||
|
||
import co.com.bancolombia.Constants; | ||
import co.com.bancolombia.factory.ModuleBuilder; | ||
import co.com.bancolombia.factory.upgrades.UpdateUtils; | ||
import co.com.bancolombia.factory.upgrades.UpgradeAction; | ||
import lombok.SneakyThrows; | ||
|
||
public class UpgradeY2024M10D17AddPitest implements UpgradeAction { | ||
private final String pitestConfig = | ||
"pitest {\n" | ||
+ " targetClasses = ['{{package}}.*']\n" | ||
+ " excludedClasses = []\n" | ||
+ " excludedTestClasses = []\n" | ||
+ " pitestVersion = '1.16.1'\n" | ||
+ " verbose = true\n" | ||
+ " outputFormats = ['XML', 'HTML']\n" | ||
+ " threads = 8\n" | ||
+ " exportLineCoverage = true\n" | ||
+ " timestampedReports = false\n" | ||
+ " //mutators = ['STRONGER', 'DEFAULTS']\n" | ||
+ " fileExtensionsToFilter.addAll('xml', 'orbit')\n" | ||
+ " junit5PluginVersion = '1.2.1'\n" | ||
+ " failWhenNoMutations = false\n" | ||
+ " jvmArgs = [\"-XX:+AllowRedefinitionToAddDeleteMethods\"]\n" | ||
+ " }\n" | ||
+ "\n" | ||
+ " "; | ||
|
||
private final String pitestMergedConfig = | ||
"\npitestReportAggregate {\n" | ||
+ " doLast {\n" | ||
+ " def reportDir = layout.buildDirectory.dir(\"reports/pitest\").get().asFile\n" | ||
+ " def consolidatedReport = new File(reportDir, 'mutations.xml')\n" | ||
+ " consolidatedReport.withWriter { writer ->\n" | ||
+ " writer.write(\"<mutations>\\n\")\n" | ||
+ " subprojects.each { subproject ->\n" | ||
+ " def xmlReport = subproject.layout.buildDirectory.file(\"reports/pitest/mutations.xml\").get().asFile\n" | ||
+ " if (xmlReport.exists()) {\n" | ||
+ " def xmlContent = xmlReport.text\n" | ||
+ " xmlContent = xmlContent.replaceAll(\"<\\\\?xml[^>]*>\", \"\")\n" | ||
+ " xmlContent = xmlContent.replaceAll(\"</?mutations( partial=\\\"true\\\")?>\", \"\")\n" | ||
+ " writer.write(xmlContent.trim() + \"\\n\")\n" | ||
+ " }\n" | ||
+ " }\n" | ||
+ " writer.write(\"</mutations>\")\n" | ||
+ " }\n" | ||
+ " }\n" | ||
+ "}\n\n"; | ||
|
||
@Override | ||
@SneakyThrows | ||
public boolean up(ModuleBuilder builder) { | ||
boolean appliedToBuildGradle = | ||
builder.updateFile( | ||
BUILD_GRADLE, | ||
content -> { | ||
String partial = | ||
UpdateUtils.insertAfterMatch( | ||
content, | ||
"ext {", | ||
"pitestVersion", | ||
"\n pitestVersion = '" + Constants.PITEST_VERSION + "'"); | ||
|
||
partial = | ||
UpdateUtils.insertAfterMatch( | ||
partial, | ||
"plugins {", | ||
"info.solidsoft.pitest", | ||
"\n id 'info.solidsoft.pitest' version \"${pitestVersion}\" apply false"); | ||
|
||
return UpdateUtils.insertAfterMatch( | ||
partial, | ||
"jacocoMergedReport.xml\"", | ||
"sonar.pitest.reportPaths", | ||
"\n property \"sonar.pitest.reportPaths\", \"build/reports/pitest/mutations.xml\""); | ||
}); | ||
boolean appliedToMainGradle = | ||
builder.updateFile( | ||
MAIN_GRADLE, | ||
content -> { | ||
String partial = | ||
UpdateUtils.addToStartIfNotContains( | ||
content, | ||
"info.solidsoft.pitest.aggregator", | ||
"apply plugin: 'info.solidsoft.pitest.aggregator'\n\n"); | ||
|
||
partial = | ||
UpdateUtils.insertAfterMatch( | ||
partial, | ||
"subprojects {", | ||
"'info.solidsoft.pitest'", | ||
"\n apply plugin: 'info.solidsoft.pitest'"); | ||
|
||
String packageLoaded = builder.getStringParam("package"); | ||
if (packageLoaded == null) { | ||
packageLoaded = "your.package"; | ||
} | ||
String pitest = pitestConfig.replace("{{package}}", packageLoaded); | ||
partial = | ||
UpdateUtils.insertBeforeMatch( | ||
partial, "jacocoTestReport {", "pitestVersion", pitest); | ||
|
||
partial = | ||
UpdateUtils.insertAfterMatch( | ||
partial, | ||
"subprojects.jacocoTestReport", | ||
"pitestReportAggregate", | ||
", pitestReportAggregate"); | ||
|
||
partial = | ||
UpdateUtils.insertAfterMatch(partial, "dependsOn test", "'pitest'", ", 'pitest'"); | ||
|
||
return UpdateUtils.insertBeforeMatch( | ||
partial, "tasks.named('wrapper')", "pitestReportAggregate {", pitestMergedConfig); | ||
}); | ||
return appliedToBuildGradle || appliedToMainGradle; | ||
} | ||
|
||
@Override | ||
public String name() { | ||
return "3.17.24->3.18"; | ||
} | ||
|
||
@Override | ||
public String description() { | ||
return "Add skipCompile for sonar"; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
63 changes: 63 additions & 0 deletions
63
...est/java/co/com/bancolombia/factory/upgrades/actions/UpgradeY2024M10D17AddPitestTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
package co.com.bancolombia.factory.upgrades.actions; | ||
|
||
import static co.com.bancolombia.Constants.MainFiles.BUILD_GRADLE; | ||
import static co.com.bancolombia.Constants.MainFiles.MAIN_GRADLE; | ||
import static org.junit.jupiter.api.Assertions.assertNotNull; | ||
import static org.junit.jupiter.api.Assertions.assertTrue; | ||
import static org.mockito.Mockito.spy; | ||
import static org.mockito.Mockito.verify; | ||
import static org.mockito.Mockito.when; | ||
|
||
import co.com.bancolombia.factory.ModuleBuilder; | ||
import co.com.bancolombia.factory.upgrades.UpgradeAction; | ||
import co.com.bancolombia.utils.FileUtils; | ||
import com.github.mustachejava.resolver.DefaultResolver; | ||
import java.io.IOException; | ||
import java.nio.file.Files; | ||
import org.gradle.api.Project; | ||
import org.gradle.api.logging.Logger; | ||
import org.junit.jupiter.api.BeforeEach; | ||
import org.junit.jupiter.api.Test; | ||
import org.junit.jupiter.api.extension.ExtendWith; | ||
import org.mockito.Mock; | ||
import org.mockito.junit.jupiter.MockitoExtension; | ||
|
||
@ExtendWith(MockitoExtension.class) | ||
class UpgradeY2024M10D17AddPitestTest { | ||
|
||
@Mock private Project project; | ||
@Mock private Logger logger; | ||
|
||
private ModuleBuilder builder; | ||
private UpgradeAction updater; | ||
|
||
@BeforeEach | ||
public void setup() throws IOException { | ||
when(project.getName()).thenReturn("UtilsTest"); | ||
when(project.getLogger()).thenReturn(logger); | ||
when(project.getProjectDir()).thenReturn(Files.createTempDirectory("sample").toFile()); | ||
|
||
builder = spy(new ModuleBuilder(project)); | ||
updater = new UpgradeY2024M10D17AddPitest(); | ||
|
||
assertNotNull(updater.name()); | ||
assertNotNull(updater.description()); | ||
} | ||
|
||
@Test | ||
void shouldApplyUpdate() throws IOException { | ||
DefaultResolver resolver = new DefaultResolver(); | ||
// Arrange | ||
builder.addFile( | ||
BUILD_GRADLE, FileUtils.getResourceAsString(resolver, "pitest/build-before.txt")); | ||
builder.addFile(MAIN_GRADLE, FileUtils.getResourceAsString(resolver, "pitest/main-before.txt")); | ||
// Act | ||
boolean applied = updater.up(builder); | ||
// Assert | ||
assertTrue(applied); | ||
verify(builder) | ||
.addFile(BUILD_GRADLE, FileUtils.getResourceAsString(resolver, "pitest/build-after.txt")); | ||
verify(builder) | ||
.addFile(MAIN_GRADLE, FileUtils.getResourceAsString(resolver, "pitest/main-after.txt")); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
buildscript { | ||
ext { | ||
pitestVersion = '1.15.0' | ||
cleanArchitectureVersion = '3.17.26' | ||
springBootVersion = '3.3.4' | ||
sonarVersion = '5.1.0.4882' | ||
jacocoVersion = '0.8.12' | ||
lombokVersion = '1.18.34' | ||
} | ||
} | ||
|
||
plugins { | ||
id 'info.solidsoft.pitest' version "${pitestVersion}" apply false | ||
id 'co.com.bancolombia.cleanArchitecture' version "${cleanArchitectureVersion}" | ||
id 'org.springframework.boot' version "${springBootVersion}" apply false | ||
id 'org.sonarqube' version "${sonarVersion}" | ||
id 'jacoco' | ||
} | ||
|
||
sonar { | ||
def modules = subprojects.projectDir.collect { "${it.toString().replace(project.projectDir.toString() + "/", "")}" } | ||
properties { | ||
property "sonar.sourceEncoding", "UTF-8" | ||
property "sonar.modules", "${modules.join(',')}" | ||
property "sonar.sources", "src,deployment,settings.gradle,main.gradle,build.gradle,${modules.collect { "${it}/build.gradle" }.join(',')}" | ||
property "sonar.test", "src/test" | ||
property "sonar.exclusions", "" | ||
property "sonar.java.binaries", "build/classes" | ||
property "sonar.junit.reportsPath", "build/test-reports" | ||
property "sonar.java.coveragePlugin", "jacoco" | ||
property "sonar.coverage.jacoco.xmlReportPaths", "build/reports/jacocoMergedReport/jacocoMergedReport.xml" | ||
property "sonar.pitest.reportPaths", "build/reports/pitest/mutations.xml" | ||
property "sonar.externalIssuesReportPaths", "build/issues.json" | ||
} | ||
} | ||
|
||
apply from: './main.gradle' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
buildscript { | ||
ext { | ||
cleanArchitectureVersion = '3.17.26' | ||
springBootVersion = '3.3.4' | ||
sonarVersion = '5.1.0.4882' | ||
jacocoVersion = '0.8.12' | ||
lombokVersion = '1.18.34' | ||
} | ||
} | ||
|
||
plugins { | ||
id 'co.com.bancolombia.cleanArchitecture' version "${cleanArchitectureVersion}" | ||
id 'org.springframework.boot' version "${springBootVersion}" apply false | ||
id 'org.sonarqube' version "${sonarVersion}" | ||
id 'jacoco' | ||
} | ||
|
||
sonar { | ||
def modules = subprojects.projectDir.collect { "${it.toString().replace(project.projectDir.toString() + "/", "")}" } | ||
properties { | ||
property "sonar.sourceEncoding", "UTF-8" | ||
property "sonar.modules", "${modules.join(',')}" | ||
property "sonar.sources", "src,deployment,settings.gradle,main.gradle,build.gradle,${modules.collect { "${it}/build.gradle" }.join(',')}" | ||
property "sonar.test", "src/test" | ||
property "sonar.exclusions", "" | ||
property "sonar.java.binaries", "build/classes" | ||
property "sonar.junit.reportsPath", "build/test-reports" | ||
property "sonar.java.coveragePlugin", "jacoco" | ||
property "sonar.coverage.jacoco.xmlReportPaths", "build/reports/jacocoMergedReport/jacocoMergedReport.xml" | ||
property "sonar.externalIssuesReportPaths", "build/issues.json" | ||
} | ||
} | ||
|
||
apply from: './main.gradle' |
Oops, something went wrong.