Add unit tests for remote queries in logs
Also, change text slightly.
This commit is contained in:
@@ -337,18 +337,22 @@ async function runRemoteQueriesApiRequest(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function parseResponse(owner: string, repo: string, response: QueriesResponse) {
|
// exported for testng only
|
||||||
const popupMessage = `Successfully scheduled runs. [Click here to see the progress](https://github.com/${owner}/${repo}/actions/runs/${response.workflowRunId}).`
|
export function parseResponse(owner: string, repo: string, response: QueriesResponse) {
|
||||||
|
const popupMessage = `Successfully scheduled runs. [Click here to see the progress](https://github.com/${owner}/${repo}/actions/runs/${response.workflow_run_id}).`
|
||||||
+ (response.errors ? '\n\nSome repositories could not be scheduled. See extension log for details.' : '');
|
+ (response.errors ? '\n\nSome repositories could not be scheduled. See extension log for details.' : '');
|
||||||
|
|
||||||
let logMessage = `Successfully scheduled runs. See https://github.com/${owner}/${repo}/actions/runs/${response.workflow_run_id}.`;
|
let logMessage = `Successfully scheduled runs. See https://github.com/${owner}/${repo}/actions/runs/${response.workflow_run_id}.`;
|
||||||
|
if (response.repositories_queried) {
|
||||||
|
logMessage += `\n\nRepositories queried:\n${response.repositories_queried.join(', ')}`;
|
||||||
|
}
|
||||||
if (response.errors) {
|
if (response.errors) {
|
||||||
logMessage += '\nSome repositories could not be scheduled.';
|
logMessage += '\n\nSome repositories could not be scheduled.';
|
||||||
if (response.errors.invalid_repositories?.length) {
|
if (response.errors.invalid_repositories?.length) {
|
||||||
logMessage += `\nInvalid repositories: ${response.errors.invalid_repositories.join(', ')}`;
|
logMessage += `\n\nInvalid repositories:\n${response.errors.invalid_repositories.join(', ')}`;
|
||||||
}
|
}
|
||||||
if (response.errors.repositories_without_database?.length) {
|
if (response.errors.repositories_without_database?.length) {
|
||||||
logMessage += `\nRepositories without databases: ${response.errors.repositories_without_database.join(', ')}`;
|
logMessage += `\n\nRepositories without databases:\n${response.errors.repositories_without_database.join(', ')}`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,103 @@
|
|||||||
|
import { expect } from 'chai';
|
||||||
|
import { parseResponse } from '../../../remote-queries/run-remote-query';
|
||||||
|
|
||||||
|
describe('run-remote-queries', () => {
|
||||||
|
describe('parseResponse', () => {
|
||||||
|
it('should parse a successful response', () => {
|
||||||
|
const result = parseResponse('org', 'name', {
|
||||||
|
workflow_run_id: 123,
|
||||||
|
repositories_queried: ['a/b', 'c/d'],
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(result.popupMessage).to.equal('Successfully scheduled runs. [Click here to see the progress](https://github.com/org/name/actions/runs/123).');
|
||||||
|
expect(result.logMessage).to.equal(
|
||||||
|
['Successfully scheduled runs. See https://github.com/org/name/actions/runs/123.',
|
||||||
|
'',
|
||||||
|
'Repositories queried:',
|
||||||
|
'a/b, c/d'].join('\n')
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should parse a response with invalid repos', () => {
|
||||||
|
const result = parseResponse('org', 'name', {
|
||||||
|
workflow_run_id: 123,
|
||||||
|
repositories_queried: ['a/b', 'c/d'],
|
||||||
|
errors: {
|
||||||
|
invalid_repositories: ['e/f', 'g/h'],
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(result.popupMessage).to.equal(
|
||||||
|
['Successfully scheduled runs. [Click here to see the progress](https://github.com/org/name/actions/runs/123).',
|
||||||
|
'',
|
||||||
|
'Some repositories could not be scheduled. See extension log for details.'].join('\n')
|
||||||
|
);
|
||||||
|
expect(result.logMessage).to.equal(
|
||||||
|
['Successfully scheduled runs. See https://github.com/org/name/actions/runs/123.',
|
||||||
|
'',
|
||||||
|
'Repositories queried:',
|
||||||
|
'a/b, c/d',
|
||||||
|
'',
|
||||||
|
'Some repositories could not be scheduled.',
|
||||||
|
'',
|
||||||
|
'Invalid repositories:',
|
||||||
|
'e/f, g/h'].join('\n')
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should parse a response with repos w/o databases', () => {
|
||||||
|
const result = parseResponse('org', 'name', {
|
||||||
|
workflow_run_id: 123,
|
||||||
|
repositories_queried: ['a/b', 'c/d'],
|
||||||
|
errors: {
|
||||||
|
repositories_without_database: ['e/f', 'g/h'],
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(result.popupMessage).to.equal(
|
||||||
|
['Successfully scheduled runs. [Click here to see the progress](https://github.com/org/name/actions/runs/123).',
|
||||||
|
'',
|
||||||
|
'Some repositories could not be scheduled. See extension log for details.'].join('\n')
|
||||||
|
);
|
||||||
|
expect(result.logMessage).to.equal(
|
||||||
|
['Successfully scheduled runs. See https://github.com/org/name/actions/runs/123.',
|
||||||
|
'',
|
||||||
|
'Repositories queried:\na/b, c/d',
|
||||||
|
'',
|
||||||
|
'Some repositories could not be scheduled.',
|
||||||
|
'',
|
||||||
|
'Repositories without databases:\ne/f, g/h'].join('\n')
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should parse a response with invalid repos and repos w/o databases', () => {
|
||||||
|
const result = parseResponse('org', 'name', {
|
||||||
|
workflow_run_id: 123,
|
||||||
|
repositories_queried: ['a/b', 'c/d'],
|
||||||
|
errors: {
|
||||||
|
invalid_repositories: ['e/f', 'g/h'],
|
||||||
|
repositories_without_database: ['i/j', 'k/l'],
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(result.popupMessage).to.equal(
|
||||||
|
['Successfully scheduled runs. [Click here to see the progress](https://github.com/org/name/actions/runs/123).',
|
||||||
|
'',
|
||||||
|
'Some repositories could not be scheduled. See extension log for details.'].join('\n')
|
||||||
|
);
|
||||||
|
expect(result.logMessage).to.equal(
|
||||||
|
['Successfully scheduled runs. See https://github.com/org/name/actions/runs/123.',
|
||||||
|
'',
|
||||||
|
'Repositories queried:\na/b, c/d',
|
||||||
|
'',
|
||||||
|
'Some repositories could not be scheduled.',
|
||||||
|
'',
|
||||||
|
'Invalid repositories:',
|
||||||
|
'e/f, g/h',
|
||||||
|
'',
|
||||||
|
'Repositories without databases:',
|
||||||
|
'i/j, k/l'].join('\n')
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user