Remove convention where Async suffix is added to functions that returns a Promise. It was a habit from C#, but is not widely used in JavaScript / TypeScript world, also bloats the code. The code is more consistent with third party dependencies/frameworks without the suffix.
52 lines
1.9 KiB
TypeScript
52 lines
1.9 KiB
TypeScript
import 'mocha';
|
|
import { expect } from 'chai';
|
|
import { parseApplication } from '@/application/Parser/ApplicationParser';
|
|
import { IApplication } from '@/domain/IApplication';
|
|
import { IUrlStatus } from './StatusChecker/IUrlStatus';
|
|
import { getUrlStatusesInParallel, IBatchRequestOptions } from './StatusChecker/BatchStatusChecker';
|
|
|
|
describe('collections', () => {
|
|
// arrange
|
|
const app = parseApplication();
|
|
const urls = collectUniqueUrls(app);
|
|
const options: IBatchRequestOptions = {
|
|
domainOptions: {
|
|
sameDomainParallelize: true, // no need to be so nice until sources start failing
|
|
// sameDomainDelayInMs: 2 /* sec */ * 1000,
|
|
},
|
|
requestOptions: {
|
|
retryExponentialBaseInMs: 3 /* sec */ * 1000,
|
|
additionalHeaders: { referer: app.info.homepage },
|
|
additionalHeadersUrlIgnore: [
|
|
'http://batcmd.com/', // Otherwise it responds with 403
|
|
],
|
|
},
|
|
};
|
|
const testTimeoutInMs = urls.length * 60000 /* 1 minute */;
|
|
it('have no dead urls', async () => {
|
|
// act
|
|
const results = await getUrlStatusesInParallel(urls, options);
|
|
// assert
|
|
const deadUrls = results.filter((r) => r.code !== 200);
|
|
expect(deadUrls).to.have.lengthOf(0, printUrls(deadUrls));
|
|
}).timeout(testTimeoutInMs);
|
|
});
|
|
|
|
function collectUniqueUrls(app: IApplication): string[] {
|
|
return app
|
|
.collections
|
|
.flatMap((a) => a.getAllScripts())
|
|
.flatMap((script) => script.documentationUrls)
|
|
.filter((url, index, array) => array.indexOf(url) === index);
|
|
}
|
|
|
|
function printUrls(statuses: IUrlStatus[]): string {
|
|
return '\n' +
|
|
statuses.map((status) =>
|
|
`- ${status.url}\n` +
|
|
(status.code ? `\tResponse code: ${status.code}` : '') +
|
|
(status.error ? `\tException: ${JSON.stringify(status.error, null, '\t')}` : ''))
|
|
.join(`\n`)
|
|
+ '\n';
|
|
}
|