Skip to content

Commit

Permalink
Merge pull request #13 from treosh/custom-scoring
Browse files Browse the repository at this point in the history
Custom scoring using min score (experiment)
  • Loading branch information
alekseykulikov authored May 31, 2020
2 parents f00b597 + caa0657 commit aeb2537
Show file tree
Hide file tree
Showing 6 changed files with 40 additions and 7 deletions.
10 changes: 5 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,23 +6,23 @@
[An example report for developers.google.com](https://googlechrome.github.io/lighthouse/viewer/?gist=d9072ab8ccb30622deab48e6d5ee229c):

<a href="https://googlechrome.github.io/lighthouse/viewer/?gist=d9072ab8ccb30622deab48e6d5ee229c">
<img width="1081" alt="Lighthouse Field Performance Plugin" src="https://user-images.githubusercontent.com/158189/83232608-be192100-a18d-11ea-9298-e89e008a9d45.png">
<img width="1162" alt="Lighthouse Field Performance Plugin" src="https://user-images.githubusercontent.com/158189/83353335-27499180-a352-11ea-8ee5-059582117a14.png">
</a>

<br />
<br />

This plugin adds a field performance category with real-world data from [Chrome UX Report](https://developers.google.com/web/tools/chrome-user-experience-report/). It's exactly like [PageSpeed Insights](https://developers.google.com/speed/pagespeed/insights/), but for your local run and with a field performance score.
This plugin adds Core Web Vitals values to your Lighthouse report. The Field Performance category includes real-user data provided by [Chrome UX Report](https://developers.google.com/web/tools/chrome-user-experience-report/). It's similar to the field section in [PageSpeed Insights](https://developers.google.com/speed/pagespeed/insights/).

The scoring algorithm uses [Core Web Vitals](https://web.dev/vitals/). It weigths values for Largest Contentful Paint, First Input Delay, and Cumulative Layout Shift. (_Note_: FCP and the origin values do not affect the score, [see the source](./src/index.js))
The scoring algorithm weighs values for Largest Contentful Paint (LCP), First Input Delay (FID), and Cumulative Layout Shift (CLS) and picks a **minimum score**. It uses Core Web Vitals assessment that expects all its metrics to pass thresholds. For example, https://edition.cnn.com/ has LCP 5.9 s (15), FID 20 ms (100), and CLS 0.02 (100). It has `poor` mark in the [Search Console](https://support.google.com/webmasters/answer/9205520), and the score is 15. (_Note_: FCP and the origin values do not affect the score, [see the source](./src/index.js))

Check out the parity between Field & Lab performance on mobile:

<img width="974" alt="Field & lab performance on mobile" src="https://user-images.githubusercontent.com/158189/83234683-fec66980-a190-11ea-9881-a03152936a7f.png">
<img width="973" alt="Field & lab performance on mobile" src="https://user-images.githubusercontent.com/158189/83353215-31b75b80-a351-11ea-801e-07f5a2b73e51.png">

And on desktop:

<img width="974" alt="Field & lab performance on desktop" src="https://user-images.githubusercontent.com/158189/83234694-01c15a00-a191-11ea-8207-b95bffb3f25a.png">
<img width="972" alt="Field & lab performance on desktop" src="https://user-images.githubusercontent.com/158189/83353212-2ebc6b00-a351-11ea-9cf8-6a04a5f0f903.png">

Sometimes field data is missing because a URL doesn't have enough anonymous traffic. In this case, the lab data is the only available measurement.

Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "lighthouse-plugin-field-performance",
"version": "2.1.1",
"version": "2.2.0",
"description": "Lighthouse plugin to display field data",
"repository": "https://github.com/treosh/lighthouse-plugin-field-performance",
"author": "Aleksey Kulikov <[email protected]>, Artem Denysov <[email protected]>",
Expand Down
32 changes: 32 additions & 0 deletions src/index.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,35 @@
const ReportScoring = require('lighthouse/lighthouse-core/scoring')
const scoreAllCategories = ReportScoring.scoreAllCategories

/**
* Monkey-patch Lighthouse's ReportScoring to support Core Web Vitals logic.
* https://github.com/GoogleChrome/lighthouse/blob/f3d0e3459d8fd15b055148dec0ae4e430df6495b/lighthouse-core/scoring.js
*
* Logic: a URL passes the Core Web Vitals assessment if all its metrics pass thresholds.
* The algorithm picks the minimum score (not `averageMean` used in Lighthouse).
*
* Theory of constraints (https://en.wikipedia.org/wiki/Theory_of_constraints): a chain is no stronger than its weakest link.
*/

/** @typedef {Object<string, {score: number}>} ResultsByAuditId */
/** @typedef {{ score: ?number, auditRefs: { id: string, weight: number }[] }} CategoryResult */

/** @param {any} configCategories @param {ResultsByAuditId} resultsByAuditId */
ReportScoring.scoreAllCategories = function (configCategories, resultsByAuditId) {
const result = scoreAllCategories(configCategories, resultsByAuditId)
const fieldPluginCategory = /** @type {CategoryResult | null} */ (result['lighthouse-plugin-field-performance'])
if (!fieldPluginCategory) return result
fieldPluginCategory.score = getMinScore(fieldPluginCategory, resultsByAuditId)
return result
}

/** @param {CategoryResult} fieldPluginCategoryResult @param {ResultsByAuditId} resultsByAuditId */
function getMinScore(fieldPluginCategoryResult, resultsByAuditId) {
const activeAuditRefs = fieldPluginCategoryResult.auditRefs.filter((auditRef) => auditRef.weight !== 0)
const scores = activeAuditRefs.map((auditRef) => resultsByAuditId[auditRef.id].score)
return scores.length ? Math.min(...scores) : 0
}

module.exports = {
audits: [
{ path: 'lighthouse-plugin-field-performance/src/audits/field-fcp.js' },
Expand Down
1 change: 1 addition & 0 deletions src/types.d.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
declare module 'lighthouse'
declare module 'lighthouse/lighthouse-cli/run'
declare module 'lighthouse/lighthouse-core/scoring'
2 changes: 1 addition & 1 deletion test/snapshots/test/index.js.md
Original file line number Diff line number Diff line change
Expand Up @@ -365,7 +365,7 @@ Generated by [AVA](https://avajs.dev).
],
description: 'These metrics show the performance of the page over the past 30 days. Data is collected anonymously in for real-world Chrome users and provided by Chrome UX Report. [Learn More](https://developers.google.com/web/tools/chrome-user-experience-report/)',
id: 'lighthouse-plugin-field-performance',
score: 0.99,
score: 0.98,
title: 'Field Performance',
}

Expand Down
Binary file modified test/snapshots/test/index.js.snap
Binary file not shown.

0 comments on commit aeb2537

Please sign in to comment.