Skip to content

Commit

Permalink
Merge pull request #336 from uhafner/comment-limit
Browse files Browse the repository at this point in the history
Make the number of line comments configurable
  • Loading branch information
uhafner authored Apr 1, 2024
2 parents d75fb39 + 9747aa9 commit 449b6bd
Show file tree
Hide file tree
Showing 3 changed files with 115 additions and 13 deletions.
48 changes: 40 additions & 8 deletions src/main/java/edu/hm/hafner/grading/CommentBuilder.java
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,9 @@
* @author Ullrich Hafner
*/
public abstract class CommentBuilder {
private int warningComments;
private int coverageComments;

/**
* Describes the type of the comment. Is the comment for a warning, a missed line, a partially covered line, or a
* survived mutation?
Expand Down Expand Up @@ -101,14 +104,28 @@ protected abstract void createComment(CommentType commentType, String relativePa
int columnStart, int columnEnd,
String details, String markDownDetails);

private void createComment(final CommentType commentType, final String relativePath,
private void createCoverageComment(final CommentType commentType, final String relativePath,
final int lineStart, final int lineEnd,
final String message, final String title) {
createComment(commentType, relativePath, lineStart, lineEnd, message, title,
createCoverageComment(commentType, relativePath, lineStart, lineEnd, message, title,
NO_COLUMN, NO_COLUMN,
NO_ADDITIONAL_DETAILS, NO_ADDITIONAL_DETAILS);
}

@SuppressWarnings("checkstyle:ParameterNumber")
private void createCoverageComment(final CommentType commentType, final String relativePath,
final int lineStart, final int lineEnd,
final String message, final String title,
final int columnStart, final int columnEnd,
final String details, final String markDownDetails) {
if (coverageComments < getMaxCoverageComments()) {
coverageComments++;

createComment(commentType, relativePath, lineStart, lineEnd, message, title, columnStart, columnEnd,
details, markDownDetails);
}
}

private Set<String> extractAdditionalSourcePaths(final List<? extends Score<?, ?>> scores) {
return scores.stream()

Check warning on line 130 in src/main/java/edu/hm/hafner/grading/CommentBuilder.java

View workflow job for this annotation

GitHub Actions / Quality Monitor

Mutation survived

One mutation survived in line 130 (EmptyObjectReturnValsMutator)
Raw output
Survived mutations:
- replaced return value with Collections.emptySet for edu/hm/hafner/grading/CommentBuilder::extractAdditionalSourcePaths (org.pitest.mutationtest.engine.gregor.mutators.returns.EmptyObjectReturnValsMutator)
.map(Score::getConfiguration)
Expand All @@ -128,9 +145,24 @@ private void createAnnotationForIssue(final Issue issue,

var text = getDescription(issue);

createComment(CommentType.WARNING, relativePath, issue.getLineStart(), issue.getLineEnd(),
issue.getMessage(), issue.getOriginName() + ": " + issue.getType(), issue.getColumnStart(),
issue.getColumnEnd(), NO_ADDITIONAL_DETAILS, text);
createWarningComment(issue, relativePath, text);
}

private void createWarningComment(final Issue issue, final String relativePath, final String text) {
if (warningComments < getMaxWarningComments()) {
warningComments++;
createComment(CommentType.WARNING, relativePath, issue.getLineStart(), issue.getLineEnd(),
issue.getMessage(), issue.getOriginName() + ": " + issue.getType(), issue.getColumnStart(),
issue.getColumnEnd(), NO_ADDITIONAL_DETAILS, text);
}
}

protected int getMaxWarningComments() {
return Integer.MAX_VALUE;
}

protected int getMaxCoverageComments() {
return Integer.MAX_VALUE;
}

private String getDescription(final Issue issue) {
Expand Down Expand Up @@ -163,7 +195,7 @@ private void createAnnotationForMissedLineRange(final FileNode file, final LineR
final Set<String> sourcePaths) {
var relativePath = createRelativeRepositoryPath(file.getRelativePath(), sourcePaths);

createComment(CommentType.NO_COVERAGE,
createCoverageComment(CommentType.NO_COVERAGE,
relativePath, range.getStart(),
range.getEnd(), getMissedLinesDescription(range),
getMissedLinesMessage(range));
Expand Down Expand Up @@ -198,7 +230,7 @@ private void createAnnotationsForMissedBranches(final FileNode file,
private void createAnnotationForMissedBranches(final FileNode file,
final Entry<Integer, Integer> branchCoverage,
final Set<String> sourcePaths) {
createComment(CommentType.PARTIAL_COVERAGE,
createCoverageComment(CommentType.PARTIAL_COVERAGE,
createRelativeRepositoryPath(file.getRelativePath(), sourcePaths), branchCoverage.getKey(),
branchCoverage.getKey(), createBranchMessage(branchCoverage.getKey(), branchCoverage.getValue()),
"Partially covered line");
Expand Down Expand Up @@ -242,7 +274,7 @@ private void createAnnotationForSurvivedMutation(final FileNode file,
final Entry<Integer, List<Mutation>> mutationsPerLine,
final Set<String> sourcePaths) {
var mutationDetails = createMutationDetails(mutationsPerLine.getValue());
createComment(CommentType.MUTATION_SURVIVED,
createCoverageComment(CommentType.MUTATION_SURVIVED,
createRelativeRepositoryPath(file.getRelativePath(), sourcePaths), mutationsPerLine.getKey(),
mutationsPerLine.getKey(),
createMutationMessage(mutationsPerLine.getKey(), mutationsPerLine.getValue()),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,7 @@ void shouldShowNoImpactsWithTwoSubResults() {
.doesNotContain("Impact");
}

private static Report createSampleReport() {
static Report createSampleReport() {
return createReportWith("CheckStyle 1",
Severity.ERROR,
Severity.WARNING_HIGH, Severity.WARNING_HIGH,
Expand Down
78 changes: 74 additions & 4 deletions src/test/java/edu/hm/hafner/grading/CommentBuilderTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
import edu.hm.hafner.coverage.registry.ParserRegistry.CoverageParserType;
import edu.hm.hafner.util.FilteredLog;

import static edu.hm.hafner.grading.AnalysisMarkdownTest.*;
import static org.mockito.Mockito.*;

class CommentBuilderTest {
Expand All @@ -30,10 +31,8 @@ class CommentBuilderTest {
""";

@Test
void shouldRunComments() {
var aggregation = new AggregatedScore(COVERAGE_CONFIGURATION, new FilteredLog("Test"));
aggregation.gradeCoverage((tool, log) -> AggregatedScoreTest.readCoverageReport(
"mutations-dashboard.xml", tool, CoverageParserType.PIT));
void shouldCreateCoverageComments() {
var aggregation = createCoverageAggregation();

CommentBuilder builder = spy(CommentBuilder.class);

Expand All @@ -43,4 +42,75 @@ void shouldRunComments() {
.createComment(any(), anyString(), anyInt(), anyInt(), anyString(), anyString(),
anyInt(), anyInt(), anyString(), anyString());
}

@Test
void shouldLimitCoverageComments() {
var aggregation = createCoverageAggregation();

CommentBuilder builder = spy(CommentBuilder.class);
when(builder.getMaxCoverageComments()).thenReturn(5);

builder.createAnnotations(aggregation);

verify(builder, times(5))
.createComment(any(), anyString(), anyInt(), anyInt(), anyString(), anyString(),
anyInt(), anyInt(), anyString(), anyString());
}

@Test
void shouldCreateWarningComments() {
var aggregation = createWarningsAggregation();

CommentBuilder builder = spy(CommentBuilder.class);

builder.createAnnotations(aggregation);

verify(builder, times(10))
.createComment(any(), anyString(), anyInt(), anyInt(), anyString(), anyString(),
anyInt(), anyInt(), anyString(), anyString());
}

@Test
void shouldLimitWarningComments() {
var aggregation = createWarningsAggregation();

CommentBuilder builder = spy(CommentBuilder.class);
when(builder.getMaxWarningComments()).thenReturn(5);

builder.createAnnotations(aggregation);

verify(builder, times(5))
.createComment(any(), anyString(), anyInt(), anyInt(), anyString(), anyString(),
anyInt(), anyInt(), anyString(), anyString());
}

private AggregatedScore createWarningsAggregation() {
var aggregation = new AggregatedScore("""
{
"analysis": [{
"tools": [
{
"id": "checkstyle",
"pattern": "target/checkstyle.xml"
}
],
"name": "CheckStyle",
"errorImpact": -1,
"highImpact": -2,
"normalImpact": -3,
"lowImpact": -4,
"maxScore": 100
}]
}
""", new FilteredLog("Test"));
aggregation.gradeAnalysis((tool, log) -> createSampleReport());
return aggregation;
}

private AggregatedScore createCoverageAggregation() {
var aggregation = new AggregatedScore(COVERAGE_CONFIGURATION, new FilteredLog("Test"));
aggregation.gradeCoverage((tool, log) -> AggregatedScoreTest.readCoverageReport(
"mutations-dashboard.xml", tool, CoverageParserType.PIT));
return aggregation;
}
}

0 comments on commit 449b6bd

Please sign in to comment.