mirror of
https://github.com/actions/stale.git
synced 2025-12-28 11:08:18 +00:00
Compare commits
4 Commits
v3.0.5
...
better_log
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6e01d91097 | ||
|
|
55ac880ddb | ||
|
|
bb7acbc692 | ||
|
|
6d710eccec |
@@ -62,36 +62,11 @@ test('empty issue list results in 1 operation', async () => {
|
|||||||
expect(operationsLeft).toEqual(99);
|
expect(operationsLeft).toEqual(99);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('processing an issue with no label will make it stale and close it, if it is old enough only if days-before-close is set to 0', async () => {
|
test('processing an issue with no label will make it stale and close it, if it is old enough', async () => {
|
||||||
const TestIssueList: Issue[] = [
|
const TestIssueList: Issue[] = [
|
||||||
generateIssue(1, 'An issue with no label', '2020-01-01T17:00:00Z')
|
generateIssue(1, 'An issue with no label', '2020-01-01T17:00:00Z')
|
||||||
];
|
];
|
||||||
|
|
||||||
const opts = {...DefaultProcessorOptions};
|
|
||||||
opts.daysBeforeClose = 0;
|
|
||||||
|
|
||||||
const processor = new IssueProcessor(
|
|
||||||
opts,
|
|
||||||
async p => (p == 1 ? TestIssueList : []),
|
|
||||||
async (num, dt) => [],
|
|
||||||
async (issue, label) => new Date().toDateString()
|
|
||||||
);
|
|
||||||
|
|
||||||
// process our fake issue list
|
|
||||||
await processor.processIssues(1);
|
|
||||||
|
|
||||||
expect(processor.staleIssues.length).toEqual(1);
|
|
||||||
expect(processor.closedIssues.length).toEqual(1);
|
|
||||||
});
|
|
||||||
|
|
||||||
test('processing an issue with no label will make it stale and not close it if days-before-close is set to > 0', async () => {
|
|
||||||
const TestIssueList: Issue[] = [
|
|
||||||
generateIssue(1, 'An issue with no label', '2020-01-01T17:00:00Z')
|
|
||||||
];
|
|
||||||
|
|
||||||
const opts = {...DefaultProcessorOptions};
|
|
||||||
opts.daysBeforeClose = 15;
|
|
||||||
|
|
||||||
const processor = new IssueProcessor(
|
const processor = new IssueProcessor(
|
||||||
DefaultProcessorOptions,
|
DefaultProcessorOptions,
|
||||||
async p => (p == 1 ? TestIssueList : []),
|
async p => (p == 1 ? TestIssueList : []),
|
||||||
@@ -103,7 +78,7 @@ test('processing an issue with no label will make it stale and not close it if d
|
|||||||
await processor.processIssues(1);
|
await processor.processIssues(1);
|
||||||
|
|
||||||
expect(processor.staleIssues.length).toEqual(1);
|
expect(processor.staleIssues.length).toEqual(1);
|
||||||
expect(processor.closedIssues.length).toEqual(0);
|
expect(processor.closedIssues.length).toEqual(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('processing an issue with no label will make it stale but not close it', async () => {
|
test('processing an issue with no label will make it stale but not close it', async () => {
|
||||||
|
|||||||
@@ -304,20 +304,6 @@ export class IssueProcessor {
|
|||||||
|
|
||||||
this.operationsLeft -= 2;
|
this.operationsLeft -= 2;
|
||||||
|
|
||||||
// We are about to modify the issue by adding a comment and applying a label, so update the modification timestamp
|
|
||||||
// to `days-before-stale` days ago to simulate as if we marked this issue stale on the very first day it actually
|
|
||||||
// became stale. This has the effect of respecting `days-before-close` no matter what value it is set to. The user
|
|
||||||
// can request to close the issue immediately by using `days-before-close` === 0, or they can set it to any number
|
|
||||||
// of days to wait before actually closing the issue.
|
|
||||||
const daysBeforeStaleInMillis =
|
|
||||||
1000 * 60 * 60 * 24 * this.options.daysBeforeStale;
|
|
||||||
const newUpdatedAtDate: Date = new Date();
|
|
||||||
newUpdatedAtDate.setTime(
|
|
||||||
newUpdatedAtDate.getTime() - daysBeforeStaleInMillis
|
|
||||||
);
|
|
||||||
|
|
||||||
issue.updated_at = newUpdatedAtDate.toString();
|
|
||||||
|
|
||||||
if (this.options.debugOnly) {
|
if (this.options.debugOnly) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -424,7 +410,7 @@ export class IssueProcessor {
|
|||||||
const millisSinceLastUpdated =
|
const millisSinceLastUpdated =
|
||||||
new Date().getTime() - new Date(timestamp).getTime();
|
new Date().getTime() - new Date(timestamp).getTime();
|
||||||
|
|
||||||
return millisSinceLastUpdated <= daysInMillis;
|
return millisSinceLastUpdated < daysInMillis;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static parseCommaSeparatedString(s: string): string[] {
|
private static parseCommaSeparatedString(s: string): string[] {
|
||||||
|
|||||||
Reference in New Issue
Block a user