2018-10-04 16:01:16 +00:00
|
|
|
const args = require('minimist')(process.argv.slice(2));
|
2023-06-22 14:21:42 +00:00
|
|
|
const fs = require('node:fs');
|
2021-08-12 17:34:49 +00:00
|
|
|
const got = require('got');
|
2023-06-22 14:21:42 +00:00
|
|
|
const stream = require('node:stream');
|
|
|
|
const { promisify } = require('node:util');
|
2018-10-04 16:01:16 +00:00
|
|
|
|
2021-08-12 17:34:49 +00:00
|
|
|
const pipeline = promisify(stream.pipeline);
|
2018-10-04 16:01:16 +00:00
|
|
|
|
|
|
|
async function downloadArtifact (name, buildNum, dest) {
|
|
|
|
const circleArtifactUrl = `https://circleci.com/api/v1.1/project/github/electron/electron/${args.buildNum}/artifacts?circle-token=${process.env.CIRCLE_TOKEN}`;
|
2021-08-12 17:34:49 +00:00
|
|
|
const responsePromise = got(circleArtifactUrl, {
|
2018-10-04 16:01:16 +00:00
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
2020-03-20 15:12:18 +00:00
|
|
|
Accept: 'application/json'
|
2018-10-04 16:01:16 +00:00
|
|
|
}
|
|
|
|
});
|
2021-08-12 17:34:49 +00:00
|
|
|
const [response, artifacts] = await Promise.all([responsePromise, responsePromise.json()]);
|
|
|
|
if (response.statusCode !== 200) {
|
|
|
|
console.error('Could not fetch circleci artifact list, got status code:', response.statusCode);
|
|
|
|
}
|
2018-10-04 16:01:16 +00:00
|
|
|
const artifactToDownload = artifacts.find(artifact => {
|
|
|
|
return (artifact.path === name);
|
|
|
|
});
|
|
|
|
if (!artifactToDownload) {
|
|
|
|
console.log(`Could not find artifact called ${name} to download for build #${buildNum}.`);
|
|
|
|
process.exit(1);
|
|
|
|
} else {
|
|
|
|
console.log(`Downloading ${artifactToDownload.url}.`);
|
2019-05-31 00:22:35 +00:00
|
|
|
let downloadError = false;
|
|
|
|
await downloadWithRetry(artifactToDownload.url, dest).catch(err => {
|
2019-06-05 16:21:57 +00:00
|
|
|
if (args.verbose) {
|
|
|
|
console.log(`${artifactToDownload.url} could not be successfully downloaded. Error was:`, err);
|
|
|
|
} else {
|
|
|
|
console.log(`${artifactToDownload.url} could not be successfully downloaded.`);
|
|
|
|
}
|
2019-05-31 00:22:35 +00:00
|
|
|
downloadError = true;
|
|
|
|
});
|
|
|
|
if (!downloadError) {
|
|
|
|
console.log(`Successfully downloaded ${name}.`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function downloadWithRetry (url, directory) {
|
|
|
|
let lastError;
|
2019-06-05 16:21:57 +00:00
|
|
|
const downloadURL = `${url}?circle-token=${process.env.CIRCLE_TOKEN}`;
|
2019-05-31 00:22:35 +00:00
|
|
|
for (let i = 0; i < 5; i++) {
|
|
|
|
console.log(`Attempting to download ${url} - attempt #${(i + 1)}`);
|
|
|
|
try {
|
2019-06-05 16:21:57 +00:00
|
|
|
return await downloadFile(downloadURL, directory);
|
2019-05-31 00:22:35 +00:00
|
|
|
} catch (err) {
|
|
|
|
lastError = err;
|
2023-06-26 09:51:54 +00:00
|
|
|
await new Promise(resolve => setTimeout(resolve, 30000));
|
2019-05-31 00:22:35 +00:00
|
|
|
}
|
2018-10-04 16:01:16 +00:00
|
|
|
}
|
2019-05-31 00:22:35 +00:00
|
|
|
throw lastError;
|
2018-10-04 16:01:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function downloadFile (url, directory) {
|
2021-08-12 17:34:49 +00:00
|
|
|
return pipeline(
|
|
|
|
got.stream(url),
|
|
|
|
fs.createWriteStream(directory)
|
|
|
|
);
|
2018-10-04 16:01:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!args.name || !args.buildNum || !args.dest) {
|
|
|
|
console.log(`Download CircleCI artifacts.
|
2019-06-05 16:21:57 +00:00
|
|
|
Usage: download-circleci-artifacts.js [--buildNum=CIRCLE_BUILD_NUMBER] [--name=artifactName] [--dest] [--verbose]`);
|
2018-10-04 16:01:16 +00:00
|
|
|
process.exit(0);
|
|
|
|
} else {
|
|
|
|
downloadArtifact(args.name, args.buildNum, args.dest);
|
|
|
|
}
|