|
| 1 | +const { env } = require('process') |
| 2 | + |
| 3 | +const { serializeErrorStatus } = require('../error/parse/serialize_status') |
| 4 | +const { logStatuses } = require('../log/main') |
| 5 | + |
| 6 | +const { removeStatusesColors } = require('./colors') |
| 7 | + |
| 8 | +// Errors that happen during plugin loads should be reported as error statuses |
| 9 | +const reportPluginLoadError = async function({ error, api, mode, event, package, version }) { |
| 10 | + const errorStatus = serializeErrorStatus(error) |
| 11 | + const statuses = [{ ...errorStatus, event, package, version }] |
| 12 | + await reportStatuses(statuses, api, mode) |
| 13 | +} |
| 14 | + |
| 15 | +const reportStatuses = async function(statuses, api, mode) { |
| 16 | + const statusesA = removeStatusesColors(statuses) |
| 17 | + printStatuses(statusesA, mode) |
| 18 | + await sendStatuses(statusesA, api, mode) |
| 19 | +} |
| 20 | + |
| 21 | +// When not in production, print statuses to console. |
| 22 | +// Only print successful ones, since errors are logged afterwards. |
| 23 | +const printStatuses = function(statuses, mode) { |
| 24 | + if (mode === 'buildbot') { |
| 25 | + return |
| 26 | + } |
| 27 | + |
| 28 | + const successStatuses = statuses.filter(shouldPrintStatus) |
| 29 | + |
| 30 | + if (successStatuses.length === 0) { |
| 31 | + return |
| 32 | + } |
| 33 | + |
| 34 | + logStatuses(successStatuses) |
| 35 | +} |
| 36 | + |
| 37 | +const shouldPrintStatus = function({ state, summary }) { |
| 38 | + return state === 'success' && summary !== undefined |
| 39 | +} |
| 40 | + |
| 41 | +// In production, send statuses to the API |
| 42 | +const sendStatuses = async function(statuses, api, mode) { |
| 43 | + if ((mode !== 'buildbot' && env.NETLIFY_BUILD_TEST_STATUS !== '1') || api === undefined || !env.DEPLOY_ID) { |
| 44 | + return |
| 45 | + } |
| 46 | + |
| 47 | + await Promise.all(statuses.map(status => sendStatus(api, status))) |
| 48 | +} |
| 49 | + |
| 50 | +const sendStatus = async function(api, { package, version, state, event, title, summary, text }) { |
| 51 | + await api.createPluginRun({ |
| 52 | + deploy_id: env.DEPLOY_ID, |
| 53 | + body: { package, version, state, reporting_event: event, title, summary, text }, |
| 54 | + }) |
| 55 | +} |
| 56 | + |
| 57 | +module.exports = { reportPluginLoadError, reportStatuses } |
0 commit comments