2020-03-20 09:59:35 -04:00
|
|
|
/**
|
|
|
|
* @license
|
2020-05-19 15:08:49 -04:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2020-03-20 09:59:35 -04:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
2020-04-16 14:12:25 -04:00
|
|
|
|
2020-05-20 17:41:44 -04:00
|
|
|
import {info} from '../utils/console';
|
2020-03-20 09:59:35 -04:00
|
|
|
import {PullApproveGroupResult} from './group';
|
|
|
|
|
2020-07-23 18:53:46 -04:00
|
|
|
type ConditionGrouping = keyof Pick<
|
|
|
|
PullApproveGroupResult, 'matchedConditions'|'unmatchedConditions'|'unverifiableConditions'>;
|
|
|
|
|
2020-03-20 09:59:35 -04:00
|
|
|
/** Create logs for each pullapprove group result. */
|
2020-07-23 18:53:46 -04:00
|
|
|
export function logGroup(
|
|
|
|
group: PullApproveGroupResult, conditionsToPrint: ConditionGrouping, printMessageFn = info) {
|
|
|
|
const conditions = group[conditionsToPrint];
|
2020-05-28 17:57:47 -04:00
|
|
|
printMessageFn.group(`[${group.groupName}]`);
|
2020-04-16 14:12:25 -04:00
|
|
|
if (conditions.length) {
|
2020-07-23 18:53:46 -04:00
|
|
|
conditions.forEach(groupCondition => {
|
|
|
|
const count = groupCondition.matchedFiles.size;
|
|
|
|
if (conditionsToPrint === 'unverifiableConditions') {
|
|
|
|
printMessageFn(`${groupCondition.expression}`);
|
|
|
|
} else {
|
|
|
|
printMessageFn(
|
|
|
|
`${count} ${count === 1 ? 'match' : 'matches'} - ${groupCondition.expression}`);
|
|
|
|
}
|
2020-04-16 14:12:25 -04:00
|
|
|
});
|
2020-05-28 17:57:47 -04:00
|
|
|
printMessageFn.groupEnd();
|
2020-03-20 09:59:35 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** 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);
|
|
|
|
|
2020-05-20 17:41:44 -04:00
|
|
|
info(`┌${fill(fillWidth, '─')}┐`);
|
|
|
|
info(`│${fill(leftSpace, ' ')}${headerText}${fill(rightSpace, ' ')}│`);
|
|
|
|
info(`└${fill(fillWidth, '─')}┘`);
|
2020-04-16 14:12:25 -04:00
|
|
|
}
|