mirror of
https://github.com/DIYgod/RSSHub.git
synced 2025-12-04 11:07:54 +08:00
chore(*): PR route test result auto-split (#9699)
Signed-off-by: Rongrong <i@rong.moe>
This commit is contained in:
@@ -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);
|
||||||
|
});
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user