@Override public void addDiag(Diag diag) { int capacity = capacityByKind.containsKey(diag.getKind()) ? capacityByKind.get(diag.getKind()) : 0; int currentCount = listByKind(diag.getKind()).size(); if (currentCount < capacity) { diags.add(diag); } else if (currentCount == capacity) { final String msg = String.format( "Hit max count(%d) of allowed %s. No more diags of this kind will be logged.", capacity, StringUtils.lowerCase(diag.getKind().toString())); diags.add(Diag.create(SimpleLocation.TOPLEVEL, "%s", diag.getKind(), msg)); // Try to short circuit proceeding in a known bad state (to avoid potential timeouts in // trying process REALLY bad configuration). if (diag.getKind() == Kind.ERROR) { throw new TooManyDiagsException(msg); } } }
.getDiags() .stream() .filter(d -> d.getKind().equals(Kind.WARNING)) .collect(Collectors.toList()); assertThat(warningDiags).isNotEmpty();
String.format( "%s: %s: %s", diagToPrint.getKind().toString(), getLocationWithoutFullPath(diagToPrint), message)
@Override public void addDiag(Diag diag) { int capacity = capacityByKind.containsKey(diag.getKind()) ? capacityByKind.get(diag.getKind()) : 0; int currentCount = listByKind(diag.getKind()).size(); if (currentCount < capacity) { diags.add(diag); } else if (currentCount == capacity) { final String msg = String.format( "Hit max count(%d) of allowed %s. No more diags of this kind will be logged.", capacity, StringUtils.lowerCase(diag.getKind().toString())); diags.add(Diag.create(SimpleLocation.TOPLEVEL, "%s", diag.getKind(), msg)); // Try to short circuit proceeding in a known bad state (to avoid potential timeouts in // trying process REALLY bad configuration). if (diag.getKind() == Kind.ERROR) { throw new TooManyDiagsException(msg); } } }
@Override public String toString() { return String.format("%s: %s: %s", getKind().toString(), getLocation().getDisplayString(), getMessage()); } }
@Override public boolean apply(Diag diag) { return Kind.ERROR.equals(diag.getKind()); } })
public static String getDiagToPrint(final Diag diag, boolean trimLocationFullPath) { String message = DiagUtils.getDiagMessage(diag); return String.format( "%s: %s: %s", diag.getKind().toString(), trimLocationFullPath ? getLocationWithoutFullPath(diag) : diag.getLocation().getDisplayString(), message); }
@Override public String toString() { return String.format("%s: %s: %s", getKind().toString(), getLocation().getDisplayString(), getMessage()); } }