mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-10 14:06:30 +00:00
Merge 47f5b9d637
into b7f96b2ea1
This commit is contained in:
commit
3668a0d0f8
2 changed files with 54 additions and 3 deletions
|
@ -53,9 +53,31 @@ describe('workers/repository/update/pr/body/config-description', () => {
|
||||||
it('renders UTC as the default timezone', () => {
|
it('renders UTC as the default timezone', () => {
|
||||||
const res = getPrConfigDescription({
|
const res = getPrConfigDescription({
|
||||||
...config,
|
...config,
|
||||||
schedule: ['* 1 * * * *'],
|
schedule: ['* 1 * * *'],
|
||||||
});
|
});
|
||||||
expect(res).toContain(`"* 1 * * * *" (UTC)`);
|
expect(res).toContain(
|
||||||
|
'Between 01:00 AM and 01:59 AM ( * 1 * * * ) (UTC)',
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('summarizes cron schedules', () => {
|
||||||
|
const res = getPrConfigDescription({
|
||||||
|
...config,
|
||||||
|
schedule: ['* 1 * * *', '* * 2 * 1'],
|
||||||
|
});
|
||||||
|
expect(res).toContain(
|
||||||
|
'Between 01:00 AM and 01:59 AM ( * 1 * * * ), On day 2 of the month, and on Monday ( * * 2 * 1 ) (UTC)',
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('displays later schedules', () => {
|
||||||
|
const res = getPrConfigDescription({
|
||||||
|
...config,
|
||||||
|
schedule: ['before 6am on Monday', 'after 3pm on Tuesday'],
|
||||||
|
});
|
||||||
|
expect(res).toContain(
|
||||||
|
'"before 6am on Monday,after 3pm on Tuesday" (UTC)',
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('renders undefined schedule', () => {
|
it('renders undefined schedule', () => {
|
||||||
|
|
|
@ -1,3 +1,6 @@
|
||||||
|
import { CronPattern } from 'croner';
|
||||||
|
import cronstrue from 'cronstrue';
|
||||||
|
import { capitalize } from '../../../../../../tools/docs/utils';
|
||||||
import { emojify } from '../../../../../util/emoji';
|
import { emojify } from '../../../../../util/emoji';
|
||||||
import type { BranchConfig } from '../../../../types';
|
import type { BranchConfig } from '../../../../types';
|
||||||
|
|
||||||
|
@ -51,7 +54,8 @@ function scheduleToString(
|
||||||
): string {
|
): string {
|
||||||
let scheduleString = '';
|
let scheduleString = '';
|
||||||
if (schedule && schedule[0] !== 'at any time') {
|
if (schedule && schedule[0] !== 'at any time') {
|
||||||
scheduleString += `"${String(schedule)}"`;
|
scheduleString =
|
||||||
|
getReadableCronSchedule(schedule) ?? `"${String(schedule)}"`;
|
||||||
if (timezone) {
|
if (timezone) {
|
||||||
scheduleString += ` in timezone ${timezone}`;
|
scheduleString += ` in timezone ${timezone}`;
|
||||||
} else {
|
} else {
|
||||||
|
@ -62,3 +66,28 @@ function scheduleToString(
|
||||||
}
|
}
|
||||||
return scheduleString;
|
return scheduleString;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return human-readable cron schedule summary if the schedule is a valid cron
|
||||||
|
* else return null
|
||||||
|
*/
|
||||||
|
function getReadableCronSchedule(scheduleText: string[]): string | null {
|
||||||
|
// assuming if one schedule is cron the others in the array will be cron too
|
||||||
|
try {
|
||||||
|
new CronPattern(scheduleText[0]); // validate cron
|
||||||
|
return scheduleText
|
||||||
|
.map(
|
||||||
|
(cron) =>
|
||||||
|
capitalize(
|
||||||
|
cronstrue
|
||||||
|
.toString(cron, {
|
||||||
|
throwExceptionOnParseError: false,
|
||||||
|
})
|
||||||
|
.replace('Every minute, ', ''),
|
||||||
|
) + ` ( ${cron} )`,
|
||||||
|
)
|
||||||
|
.join(', ');
|
||||||
|
} catch {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue