There are a few changes in this PR to ensure conditions that are based
on groups (i.e. `- groups.pending.length == 0`) do not fail the verify
task:
* Remove the warning when a condition is encountered that depends on the
`groups` state. The warning will otherwise be printed once for every
file that triggers the execution of the condition (400,000+ times)
* Add an `unverifiable` flag to `GroupCondition` interface and set it to
true when an error is encountered due to attempting to get the state of
`groups` in a condition
* Ignore any unverifiable conditions when gathering unmatched
conditions. These should not be considered `unmatched` for verification
purposes.
* Print the unverifiable conditions by group in the results
Sample output:
```
┌──────────────────────────────────────────────────────────────────────────────┐
│ PullApprove results by group │
└──────────────────────────────────────────────────────────────────────────────┘
Groups skipped (4 groups)
Matched conditions by Group (37 groups)
Unmatched conditions by Group (0 groups)
Unverifiable conditions by Group (3 groups)
[public-api]
len(groups.pending.exclude("required-minimum-review")...
len(groups.rejected.exclude("required-minimum-review")...
[size-tracking]
len(groups.pending.exclude("required-minimum-review")...
len(groups.rejected.exclude("required-minimum-review")...
[circular-dependencies]
len(groups.pending.exclude("required-minimum-review")...
len(groups.rejected.exclude("required-minimum-review")...
```
PR Close #37798
47 lines
1.7 KiB
TypeScript
47 lines
1.7 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
|
|
import {info} from '../utils/console';
|
|
import {PullApproveGroupResult} from './group';
|
|
|
|
type ConditionGrouping = keyof Pick<
|
|
PullApproveGroupResult, 'matchedConditions'|'unmatchedConditions'|'unverifiableConditions'>;
|
|
|
|
/** Create logs for each pullapprove group result. */
|
|
export function logGroup(
|
|
group: PullApproveGroupResult, conditionsToPrint: ConditionGrouping, printMessageFn = info) {
|
|
const conditions = group[conditionsToPrint];
|
|
printMessageFn.group(`[${group.groupName}]`);
|
|
if (conditions.length) {
|
|
conditions.forEach(groupCondition => {
|
|
const count = groupCondition.matchedFiles.size;
|
|
if (conditionsToPrint === 'unverifiableConditions') {
|
|
printMessageFn(`${groupCondition.expression}`);
|
|
} else {
|
|
printMessageFn(
|
|
`${count} ${count === 1 ? 'match' : 'matches'} - ${groupCondition.expression}`);
|
|
}
|
|
});
|
|
printMessageFn.groupEnd();
|
|
}
|
|
}
|
|
|
|
/** Logs a header within a text drawn box. */
|
|
export function logHeader(...params: string[]) {
|
|
const totalWidth = 80;
|
|
const fillWidth = totalWidth - 2;
|
|
const headerText = params.join(' ').substr(0, fillWidth);
|
|
const leftSpace = Math.ceil((fillWidth - headerText.length) / 2);
|
|
const rightSpace = fillWidth - leftSpace - headerText.length;
|
|
const fill = (count: number, content: string) => content.repeat(count);
|
|
|
|
info(`┌${fill(fillWidth, '─')}┐`);
|
|
info(`│${fill(leftSpace, ' ')}${headerText}${fill(rightSpace, ' ')}│`);
|
|
info(`└${fill(fillWidth, '─')}┘`);
|
|
}
|