3414 lines
189 KiB
TypeScript
3414 lines
189 KiB
TypeScript
|
import {Issue} from '../src/classes/issue';
|
||
|
import {IssuesProcessor} from '../src/classes/issues-processor';
|
||
|
import {IIssuesProcessorOptions} from '../src/interfaces/issues-processor-options';
|
||
|
import {DefaultProcessorOptions} from './constants/default-processor-options';
|
||
|
import {generateIssue} from './functions/generate-issue';
|
||
|
|
||
|
interface ITestData {
|
||
|
isPullRequest: boolean;
|
||
|
milestone: string;
|
||
|
name: string;
|
||
|
shouldStale: boolean;
|
||
|
exemptAllMilestones: boolean;
|
||
|
}
|
||
|
|
||
|
describe('milestones options', (): void => {
|
||
|
let opts: IIssuesProcessorOptions;
|
||
|
let testIssueList: Issue[];
|
||
|
let processor: IssuesProcessor;
|
||
|
|
||
|
const setTestIssueList = (
|
||
|
isPullRequest: boolean,
|
||
|
milestone: string | undefined
|
||
|
) => {
|
||
|
testIssueList = [
|
||
|
generateIssue(
|
||
|
opts,
|
||
|
1,
|
||
|
'My first issue',
|
||
|
'2020-01-01T17:00:00Z',
|
||
|
'2020-01-01T17:00:00Z',
|
||
|
isPullRequest,
|
||
|
undefined,
|
||
|
undefined,
|
||
|
undefined,
|
||
|
milestone
|
||
|
)
|
||
|
];
|
||
|
};
|
||
|
|
||
|
const setProcessor = () => {
|
||
|
processor = new IssuesProcessor(
|
||
|
opts,
|
||
|
async () => 'abot',
|
||
|
async p => (p === 1 ? testIssueList : []),
|
||
|
async () => [],
|
||
|
async () => new Date().toDateString()
|
||
|
);
|
||
|
};
|
||
|
|
||
|
beforeEach((): void => {
|
||
|
opts = {...DefaultProcessorOptions};
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should not exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllMilestones = false;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones are not configured to exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllIssueMilestones = undefined;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues milestones should not exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllIssueMilestones = false;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues milestones should exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllIssueMilestones = true;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones are not configured to exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllPrMilestones = undefined;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should not exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllPrMilestones = false;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllPrMilestones = true;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllMilestones = true;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones are not configured to exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllIssueMilestones = undefined;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues milestones should not exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllIssueMilestones = false;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${true}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${true}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues milestones should exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllIssueMilestones = true;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones are not configured to exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllPrMilestones = undefined;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should not exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllPrMilestones = false;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${true}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${true}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${true}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptAllPrMilestones = true;
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones = 'dummy-issue-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones = 'dummy-pull-request-milestone';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when all the issues and pull requests milestones should exempt some milestones', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptMilestones = 'dummy-milestone1, dummy-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
|
||
|
describe('when all the issues milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptIssueMilestones =
|
||
|
'dummy-issue-milestone1, dummy-issue-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-issue-milestone2'} | ${'the issue does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-issue-milestone2'} | ${'the PR does have a milestone matching the specific issue exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
describe('when all the pull requests milestones should exempt a specific milestone', (): void => {
|
||
|
beforeEach((): void => {
|
||
|
opts.exemptPrMilestones =
|
||
|
'dummy-pull-request-milestone1, dummy-pull-request-milestone2';
|
||
|
});
|
||
|
|
||
|
describe.each`
|
||
|
isPullRequest | milestone | name | shouldStale
|
||
|
${false} | ${''} | ${'the issue does not have a milestone'} | ${true}
|
||
|
${false} | ${'dummy-milestone-not-exempted'} | ${'the issue does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-pull-request-milestone2'} | ${'the issue does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${false} | ${'dummy-milestone2'} | ${'the issue does have a milestone matching the specific exempted one'} | ${false}
|
||
|
${true} | ${''} | ${'the PR does not have a milestone'} | ${true}
|
||
|
${true} | ${'dummy-milestone-not-exempted'} | ${'the PR does have a milestone but not matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-pull-request-milestone2'} | ${'the PR does have a milestone matching the specific pull request exempted one'} | ${false}
|
||
|
${true} | ${'dummy-milestone2'} | ${'the PR does have a milestone matching the specific exempted one'} | ${false}
|
||
|
`(
|
||
|
'when $name',
|
||
|
({isPullRequest, milestone, shouldStale}: ITestData): void => {
|
||
|
beforeEach((): void => {
|
||
|
setTestIssueList(isPullRequest, milestone);
|
||
|
setProcessor();
|
||
|
});
|
||
|
|
||
|
test(`should${
|
||
|
shouldStale ? '' : ' not'
|
||
|
} be marked as stale`, async () => {
|
||
|
expect.assertions(3);
|
||
|
|
||
|
await processor.processIssues(1);
|
||
|
|
||
|
expect(processor.staleIssues.length).toStrictEqual(
|
||
|
shouldStale ? 1 : 0
|
||
|
);
|
||
|
expect(processor.closedIssues.length).toStrictEqual(0);
|
||
|
expect(processor.removedLabelIssues.length).toStrictEqual(0);
|
||
|
});
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|