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, '─')}┘`);
 | 
						|
}
 |