UNPKG

calibre

Version:

Performance monitoring with Synthetic testing, Chrome UX Report, and Real User Metrics

85 lines (73 loc) 2.18 kB
import ora from 'ora' import columnify from 'columnify' import { format as dateFormat } from 'date-fns' import { history } from '../../api/rum.js' import { format } from '../../utils/formatters/index.js' import { humaniseError } from '../../utils/api-error.js' import { options } from '../../utils/cli.js' import { rumFilterOptions } from '../../utils/rum-options.js' import { colorByGrading } from '../../views/grading.js' const main = async args => { let result let spinner if (!args.json) { spinner = ora('Connecting to Calibre').start() } try { result = await history(args) if (args.json) return console.log(JSON.stringify(result, null, 2)) } catch (e) { if (args.json) return console.error(e) spinner.fail() throw new Error(humaniseError(e)) } if (!result.history || result.history.length === 0) { spinner.fail( 'No RUM history available. Check that RUM is enabled for this site with: calibre rum config --site=<slug>' ) return } spinner.succeed('RUM History') const formatters = new Map( (result.metrics || []).map(m => [m.value, m.formatter]) ) const entries = result.history.slice(0, args.limit) const rows = entries.map(entry => { const data = new Map(Object.entries(entry)) const fmt = key => colorByGrading( data.get(key) !== null ? format({ formatter: formatters.get(key), value: data.get(key) }) : null, data.get(`${key}Grading`) ) return { date: dateFormat(new Date(entry.date), 'd-MMM-yyyy'), lcp: fmt('lcp'), cls: fmt('cls'), inp: fmt('inp'), fcp: fmt('fcp'), ttfb: fmt('ttfb'), sessions: entry.sessionCount || '—' } }) console.log( columnify(rows, { columnSplitter: ' | ' }) ) } const command = 'history [options]' const describe = 'Display Real User Metrics (RUM) historical trends.' const handler = main const builder = { site: options.site, json: options.json, ...rumFilterOptions, limit: { describe: 'Number of history entries to display.', default: 25, type: 'number' } } export { command, describe, handler, builder }