chore(*): PR route test result auto-split (#9699)

Signed-off-by: Rongrong <i@rong.moe>
This commit is contained in:
Rongrong
2022-05-06 04:38:15 +08:00
committed by GitHub
parent 955de7d52a
commit 3d21235b40

View File

@@ -10,47 +10,60 @@ module.exports = async ({ github, context, core, got }, baseUrl, routes, number)
return `${baseUrl}${l}`; return `${baseUrl}${l}`;
}); });
let com = `Successfully [generated](https://github.com/${context.repo.owner}/${context.repo.repo}/actions/runs/${context.runId}) as following:\n\n`; let com_l = [];
let com = `Successfully [generated](https://github.com/${context.repo.owner}/${context.repo.repo}/actions/runs/${context.runId}) as following:\n`;
for (const lks of links) { for (const lks of links) {
core.info(`testing route: ${lks}`); core.info(`testing route: ${lks}`);
// Intended, one at a time // Intended, one at a time
const res = await got(lks).catch((err) => { let success = false;
let errMsg = err.toString(); let detail = 'no detail';
try {
const res = await got(lks);
if (res && res.body) {
success = true;
detail = res.body.replace(/\s+(\n|$)/g, '\n');
}
} catch (err) {
detail = err.toString();
const errInfoList = err.response && err.response.body && err.response.body.match(/(?<=<pre class="message">)(.+?)(?=<\/pre>)/gs); const errInfoList = err.response && err.response.body && err.response.body.match(/(?<=<pre class="message">)(.+?)(?=<\/pre>)/gs);
if (errInfoList) { if (errInfoList) {
errMsg += '\n\n'; detail += '\n\n';
errMsg += errInfoList detail += errInfoList
.slice(0, 3) .slice(0, 3)
.map((e) => e.trim()) .map((e) => e.trim())
.join('\n'); .join('\n');
} }
com += ` }
<details>
<summary><a href="${lks}">${lks}</a> - <b>Failed</b></summary>
\`\`\` let temp_com = `
${errMsg} <details>
<summary><a href="${lks}">${lks}</a> - ${success ? 'Success' : '<b>Failed</b>'}</summary>
\`\`\`${success ? 'rss' : ''}`;
temp_com += `
${detail.slice(0, 65300 - temp_com.length)}
\`\`\` \`\`\`
</details> </details>
`;
});
if (res && res.body) {
const { body } = res;
com += `
<details>
<summary><a href="${lks}">${lks}</a> - Success</summary>
\`\`\`rss
${body.replace(/\s+(\n|$)/g, '\n')}
\`\`\`
</details>
`; `;
if (com.length + temp_com.length >= 65500) {
com += '\n\n...';
com_l.push(com);
com = temp_com;
} else {
com += temp_com;
} }
} }
github.rest.issues
if (com.length > 0) {
com_l.push(com);
}
if (com_l.length >= 5) {
com_l = com_l.slice(0, 5);
}
await github.rest.issues
.addLabels({ .addLabels({
issue_number: number, issue_number: number,
owner: context.repo.owner, owner: context.repo.owner,
@@ -60,14 +73,18 @@ ${body.replace(/\s+(\n|$)/g, '\n')}
.catch((e) => { .catch((e) => {
core.warning(e); core.warning(e);
}); });
github.rest.issues
.createComment({ for (const com_s of com_l) {
issue_number: number, // Intended, one at a time
owner: context.repo.owner, await github.rest.issues
repo: context.repo.repo, .createComment({
body: com, issue_number: number,
}) owner: context.repo.owner,
.catch((e) => { repo: context.repo.repo,
core.warning(e); body: com_s,
}); })
.catch((e) => {
core.warning(e);
});
}
}; };