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

[#9631] Format values as a chart #11462

Merged
merged 1 commit into from
Sep 4, 2024
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
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@

import com.navercorp.pinpoint.common.server.util.time.Range;
import com.navercorp.pinpoint.common.server.util.time.RangeValidator;
import com.navercorp.pinpoint.exceptiontrace.web.mapper.ExceptionEntityMapper;
import com.navercorp.pinpoint.exceptiontrace.web.mapper.ExceptionModelMapper;
import com.navercorp.pinpoint.exceptiontrace.web.model.ExceptionGroupSummary;
import com.navercorp.pinpoint.exceptiontrace.web.view.ExceptionChartValueView;
import com.navercorp.pinpoint.exceptiontrace.web.service.ExceptionTraceService;
Expand All @@ -29,6 +31,7 @@
import com.navercorp.pinpoint.common.server.util.timewindow.TimeWindow;
import com.navercorp.pinpoint.common.server.util.timewindow.TimeWindowSampler;
import com.navercorp.pinpoint.common.server.util.timewindow.TimeWindowSlotCentricSampler;
import com.navercorp.pinpoint.exceptiontrace.web.view.ExceptionGroupSummaryView;
import com.navercorp.pinpoint.metric.web.util.TimePrecision;
import com.navercorp.pinpoint.pinot.tenant.TenantProvider;
import jakarta.validation.constraints.NotBlank;
Expand Down Expand Up @@ -70,14 +73,19 @@
@Value("${pinpoint.modules.web.exceptiontrace.table:exceptionTrace}")
private String tableName;

private final ExceptionModelMapper mapper;


public ExceptionTraceController(
ExceptionTraceService exceptionTraceService,
TenantProvider tenantProvider,
@Qualifier("rangeValidator7d") RangeValidator rangeValidator
@Qualifier("rangeValidator7d") RangeValidator rangeValidator,
ExceptionModelMapper mapper
) {
this.exceptionTraceService = Objects.requireNonNull(exceptionTraceService, "exceptionTraceService");
this.tenantProvider = Objects.requireNonNull(tenantProvider, "tenantProvider");
this.rangeValidator = Objects.requireNonNull(rangeValidator, "rangeValidator");
this.mapper = Objects.requireNonNull(mapper, "mapper");

Check warning on line 88 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/controller/ExceptionTraceController.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/controller/ExceptionTraceController.java#L88

Added line #L88 was not covered by tests
}

@GetMapping("/transactionInfo")
Expand Down Expand Up @@ -135,7 +143,7 @@
}

@GetMapping("/errorList/groupBy")
public List<ExceptionGroupSummary> getListOfExceptionMetaDataWithDynamicGroupBy(
public List<ExceptionGroupSummaryView> getListOfExceptionMetaDataWithDynamicGroupBy(
@RequestParam("applicationName") @NotBlank String applicationName,
@RequestParam(value = "agentId", required = false) String agentId,
@RequestParam("from") @PositiveOrZero long from,
Expand All @@ -159,7 +167,9 @@
.build();
return exceptionTraceService.getGroupSummaries(
queryParameter
);
).stream().map(
(ExceptionGroupSummary e) -> mapper.toSummaryView(e, timeWindow)
).toList();

Check warning on line 172 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/controller/ExceptionTraceController.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/controller/ExceptionTraceController.java#L170-L172

Added lines #L170 - L172 were not covered by tests
}

@GetMapping("/chart")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
package com.navercorp.pinpoint.exceptiontrace.web.mapper;

import com.navercorp.pinpoint.common.server.mapper.MapStructUtils;
import com.navercorp.pinpoint.common.server.util.timewindow.TimeWindow;
import com.navercorp.pinpoint.common.util.StringUtils;
import com.navercorp.pinpoint.exceptiontrace.common.model.ExceptionMetaData;
import com.navercorp.pinpoint.exceptiontrace.web.entity.ExceptionChartValueViewEntity;
Expand All @@ -27,8 +28,11 @@
import com.navercorp.pinpoint.exceptiontrace.web.model.GroupedFieldName;
import com.navercorp.pinpoint.exceptiontrace.web.model.params.GroupFilterParams;
import com.navercorp.pinpoint.exceptiontrace.web.util.GroupByAttributes;
import com.navercorp.pinpoint.exceptiontrace.web.util.TimeSeriesUtils;
import com.navercorp.pinpoint.exceptiontrace.web.view.ExceptionChartValueView;
import com.navercorp.pinpoint.exceptiontrace.web.view.ExceptionChartView;
import com.navercorp.pinpoint.exceptiontrace.web.view.ExceptionDetailView;
import com.navercorp.pinpoint.exceptiontrace.web.view.ExceptionGroupSummaryView;
import org.mapstruct.AfterMapping;
import org.mapstruct.CollectionMappingStrategy;
import org.mapstruct.InjectionStrategy;
Expand Down Expand Up @@ -68,6 +72,8 @@ public interface ExceptionEntityMapper {
ExceptionDetailView toDetailView(ExceptionMetaDataEntity entity);

@Mappings({
@Mapping(target = "groupedFieldName", ignore = true),
@Mapping(target = "groupFilterParams", ignore = true),
@Mapping(source = "entity.values", target = "values", qualifiedBy = MapStructUtils.JsonStrToList.class),
@Mapping(target = "tags", ignore = true),
})
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
/*
* Copyright 2024 NAVER Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.navercorp.pinpoint.exceptiontrace.web.mapper;

import com.navercorp.pinpoint.common.server.mapper.MapStructUtils;
import com.navercorp.pinpoint.common.server.util.timewindow.TimeWindow;
import com.navercorp.pinpoint.exceptiontrace.web.model.ExceptionGroupSummary;
import com.navercorp.pinpoint.exceptiontrace.web.model.GroupedFieldName;
import com.navercorp.pinpoint.exceptiontrace.web.model.params.GroupFilterParams;
import com.navercorp.pinpoint.exceptiontrace.web.util.TimeSeriesUtils;
import com.navercorp.pinpoint.exceptiontrace.web.view.ExceptionChartValueView;
import com.navercorp.pinpoint.exceptiontrace.web.view.ExceptionChartView;
import com.navercorp.pinpoint.exceptiontrace.web.view.ExceptionGroupSummaryView;
import org.mapstruct.AfterMapping;
import org.mapstruct.CollectionMappingStrategy;
import org.mapstruct.InjectionStrategy;
import org.mapstruct.Mapper;
import org.mapstruct.Mapping;
import org.mapstruct.MappingTarget;
import org.mapstruct.Mappings;
import org.mapstruct.Named;

import java.util.List;

/**
* @author intr3p1d
*/
@Mapper(
componentModel = "spring",
injectionStrategy = InjectionStrategy.CONSTRUCTOR,
uses = {
}
)
public interface ExceptionModelMapper {

@Mappings({
@Mapping(target = "chart", ignore = true),
})
ExceptionGroupSummaryView toSummaryView (
ExceptionGroupSummary summary,
TimeWindow timeWindow
);

@AfterMapping
default void addChartView(
ExceptionGroupSummary summary,
TimeWindow timeWindow,
@MappingTarget ExceptionGroupSummaryView summaryView
) {
ExceptionChartValueView exceptionChartValueView = new ExceptionChartValueView(summary.getValues());
exceptionChartValueView.setGroupedFieldName(summary.getGroupedFieldName());

Check warning on line 64 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/mapper/ExceptionModelMapper.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/mapper/ExceptionModelMapper.java#L63-L64

Added lines #L63 - L64 were not covered by tests

summaryView.setChart(TimeSeriesUtils.newChartView(

Check warning on line 66 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/mapper/ExceptionModelMapper.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/mapper/ExceptionModelMapper.java#L66

Added line #L66 was not covered by tests
"summary", timeWindow,
List.of(exceptionChartValueView)

Check warning on line 68 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/mapper/ExceptionModelMapper.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/mapper/ExceptionModelMapper.java#L68

Added line #L68 was not covered by tests
));
}

Check warning on line 70 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/mapper/ExceptionModelMapper.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/mapper/ExceptionModelMapper.java#L70

Added line #L70 was not covered by tests
}
Original file line number Diff line number Diff line change
Expand Up @@ -62,10 +62,12 @@ public void setCount(long count) {
}

@JsonProperty("fieldName")
@Override
public GroupedFieldName getGroupedFieldName() {
return groupedFieldName;
}

@Override
public void setGroupedFieldName(GroupedFieldName groupedFieldName) {
this.groupedFieldName = groupedFieldName;
}
Expand Down Expand Up @@ -145,6 +147,8 @@ public String toString() {
", groupFilterParams=" + groupFilterParams +
", mostRecentErrorClass='" + mostRecentErrorClass + '\'' +
", mostRecentErrorMessage='" + mostRecentErrorMessage + '\'' +
", firstLineOfClassName='" + firstLineOfClassName + '\'' +
", firstLineOfMethodName='" + firstLineOfMethodName + '\'' +
", firstOccurred=" + firstOccurred +
", lastOccurred=" + lastOccurred +
", lastTransactionSearchParams=" + lastTransactionSearchParams +
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@
/*
* Copyright 2024 NAVER Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.navercorp.pinpoint.exceptiontrace.web.view;

import com.navercorp.pinpoint.exceptiontrace.web.model.GroupedFieldName;
import com.navercorp.pinpoint.exceptiontrace.web.model.params.GroupFilterParams;
import com.navercorp.pinpoint.exceptiontrace.web.model.params.TransactionSearchParams;


/**
* @author intr3p1d
*/
public class ExceptionGroupSummaryView {

private ExceptionChartView chart;
private long count;

private GroupedFieldName groupedFieldName;
private GroupFilterParams groupFilterParams;

private String mostRecentErrorClass;
private String mostRecentErrorMessage;
private String firstLineOfClassName;
private String firstLineOfMethodName;
private long firstOccurred;
private long lastOccurred;

private TransactionSearchParams lastTransactionSearchParams;


public ExceptionGroupSummaryView() {
}

Check warning on line 45 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L44-L45

Added lines #L44 - L45 were not covered by tests

public ExceptionChartView getChart() {
return chart;

Check warning on line 48 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L48

Added line #L48 was not covered by tests
}

public void setChart(ExceptionChartView chart) {
this.chart = chart;
}

Check warning on line 53 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L52-L53

Added lines #L52 - L53 were not covered by tests

public long getCount() {
return count;

Check warning on line 56 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L56

Added line #L56 was not covered by tests
}

public void setCount(long count) {
this.count = count;
}

Check warning on line 61 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L60-L61

Added lines #L60 - L61 were not covered by tests

public GroupedFieldName getGroupedFieldName() {
return groupedFieldName;

Check warning on line 64 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L64

Added line #L64 was not covered by tests
}

public void setGroupedFieldName(GroupedFieldName groupedFieldName) {
this.groupedFieldName = groupedFieldName;
}

Check warning on line 69 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L68-L69

Added lines #L68 - L69 were not covered by tests

public GroupFilterParams getGroupFilterParams() {
return groupFilterParams;

Check warning on line 72 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L72

Added line #L72 was not covered by tests
}

public void setGroupFilterParams(GroupFilterParams groupFilterParams) {
this.groupFilterParams = groupFilterParams;
}

Check warning on line 77 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L76-L77

Added lines #L76 - L77 were not covered by tests

public String getMostRecentErrorClass() {
return mostRecentErrorClass;

Check warning on line 80 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L80

Added line #L80 was not covered by tests
}

public void setMostRecentErrorClass(String mostRecentErrorClass) {
this.mostRecentErrorClass = mostRecentErrorClass;
}

Check warning on line 85 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L84-L85

Added lines #L84 - L85 were not covered by tests

public String getMostRecentErrorMessage() {
return mostRecentErrorMessage;

Check warning on line 88 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L88

Added line #L88 was not covered by tests
}

public void setMostRecentErrorMessage(String mostRecentErrorMessage) {
this.mostRecentErrorMessage = mostRecentErrorMessage;
}

Check warning on line 93 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L92-L93

Added lines #L92 - L93 were not covered by tests

public String getFirstLineOfClassName() {
return firstLineOfClassName;

Check warning on line 96 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L96

Added line #L96 was not covered by tests
}

public void setFirstLineOfClassName(String firstLineOfClassName) {
this.firstLineOfClassName = firstLineOfClassName;
}

Check warning on line 101 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L100-L101

Added lines #L100 - L101 were not covered by tests

public String getFirstLineOfMethodName() {
return firstLineOfMethodName;

Check warning on line 104 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L104

Added line #L104 was not covered by tests
}

public void setFirstLineOfMethodName(String firstLineOfMethodName) {
this.firstLineOfMethodName = firstLineOfMethodName;
}

Check warning on line 109 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L108-L109

Added lines #L108 - L109 were not covered by tests

public long getFirstOccurred() {
return firstOccurred;

Check warning on line 112 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L112

Added line #L112 was not covered by tests
}

public void setFirstOccurred(long firstOccurred) {
this.firstOccurred = firstOccurred;
}

Check warning on line 117 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L116-L117

Added lines #L116 - L117 were not covered by tests

public long getLastOccurred() {
return lastOccurred;

Check warning on line 120 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L120

Added line #L120 was not covered by tests
}

public void setLastOccurred(long lastOccurred) {
this.lastOccurred = lastOccurred;
}

Check warning on line 125 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L124-L125

Added lines #L124 - L125 were not covered by tests

public TransactionSearchParams getLastTransactionSearchParams() {
return lastTransactionSearchParams;

Check warning on line 128 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L128

Added line #L128 was not covered by tests
}

public void setLastTransactionSearchParams(TransactionSearchParams lastTransactionSearchParams) {
this.lastTransactionSearchParams = lastTransactionSearchParams;
}

Check warning on line 133 in exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java

View check run for this annotation

Codecov / codecov/patch

exceptiontrace/exceptiontrace-web/src/main/java/com/navercorp/pinpoint/exceptiontrace/web/view/ExceptionGroupSummaryView.java#L132-L133

Added lines #L132 - L133 were not covered by tests
}