зеркало из https://github.com/mozilla/gecko-dev.git
70 строки
1.8 KiB
JavaScript
70 строки
1.8 KiB
JavaScript
let taskcluster = require("taskcluster-client");
|
|
|
|
// Create instance of index client
|
|
let index = new taskcluster.Index({
|
|
delayFactor: 750, // Good solid delay for background process
|
|
retries: 8, // A few extra retries for robustness
|
|
rootUrl:
|
|
process.env.TASKCLUSTER_PROXY_URL || process.env.TASKCLUSTER_ROOT_URL,
|
|
});
|
|
|
|
// Create queue instance for fetching taskId
|
|
let queue = new taskcluster.Queue({
|
|
delayFactor: 750, // Good solid delay for background process
|
|
retries: 8, // A few extra retries for robustness
|
|
rootUrl:
|
|
process.env.TASKCLUSTER_PROXY_URL || process.env.TASKCLUSTER_ROOT_URL,
|
|
});
|
|
|
|
// Load input
|
|
let taskId = process.env.TARGET_TASKID;
|
|
let rank = parseInt(process.env.INDEX_RANK, 10);
|
|
let namespaces = process.argv.slice(2);
|
|
|
|
// Validate input
|
|
if (!taskId) {
|
|
console.log("Expected target task as environment variable: TARGET_TASKID");
|
|
process.exit(1);
|
|
}
|
|
|
|
if (isNaN(rank)) {
|
|
console.log("Expected index rank as environment variable: INDEX_RANK");
|
|
process.exit(1);
|
|
}
|
|
|
|
// Fetch task definition to get expiration and then insert into index
|
|
queue
|
|
.task(taskId)
|
|
.then(task => task.expires)
|
|
.then(expires => {
|
|
return Promise.all(
|
|
namespaces.map(namespace => {
|
|
console.log(
|
|
"Inserting %s into index (rank %d) under: %s",
|
|
taskId,
|
|
rank,
|
|
namespace
|
|
);
|
|
return index.insertTask(namespace, {
|
|
taskId,
|
|
rank,
|
|
data: {},
|
|
expires,
|
|
});
|
|
})
|
|
);
|
|
})
|
|
.then(() => {
|
|
console.log("indexing successfully completed.");
|
|
process.exit(0);
|
|
})
|
|
.catch(err => {
|
|
console.log("Error:\n%s", err);
|
|
if (err.stack) {
|
|
console.log("Stack:\n%s", err.stack);
|
|
}
|
|
console.log("Properties:\n%j", err);
|
|
throw err;
|
|
})
|
|
.catch(() => process.exit(1));
|