Skip to content

Commit

Permalink
move method to util
Browse files Browse the repository at this point in the history
  • Loading branch information
paulirish committed Jul 31, 2018
1 parent d778f8b commit bbb4c8b
Show file tree
Hide file tree
Showing 7 changed files with 36 additions and 27 deletions.
2 changes: 1 addition & 1 deletion lighthouse-core/gather/computed/screenshots.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ class ScreenshotFilmstrip extends ComputedArtifact {
.map(evt => {
return {
timestamp: evt.ts / 1000,
datauri: `data:image/jpg;base64,${evt.args.snapshot}`,
datauri: `data:image/jpeg;base64,${evt.args.snapshot}`,
};
});
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -198,16 +198,6 @@ class PerformanceCategoryRenderer extends CategoryRenderer {
element.appendChild(passedElem);
return element;
}

/**
* @param {LH.ReportResult.Category} category
* @return {null|string}
*/
static getFinalScreenshot(category) {
const auditRef = category.auditRefs.find(audit => audit.id === 'final-screenshot');
if (!auditRef || !auditRef.result || auditRef.result.scoreDisplayMode === 'error') return null;
return auditRef.result.details.items[0].data;
}
}

if (typeof module !== 'undefined' && module.exports) {
Expand Down
10 changes: 10 additions & 0 deletions lighthouse-core/report/html/renderer/util.js
Original file line number Diff line number Diff line change
Expand Up @@ -328,6 +328,16 @@ class Util {
];
}

/**
* @param {LH.ReportResult.Category} category
* @return {null|string}
*/
static getFinalScreenshot(category) {
const auditRef = category.auditRefs.find(audit => audit.id === 'final-screenshot');
if (!auditRef || !auditRef.result || auditRef.result.scoreDisplayMode === 'error') return null;
return auditRef.result.details.items[0].data;
}

/**
* @param {LH.Config.Settings} settings
* @return {{deviceEmulation: string, networkThrottling: string, cpuThrottling: string, summary: string}}
Expand Down
2 changes: 1 addition & 1 deletion lighthouse-core/test/gather/computed/screenshots-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ describe('Screenshot gatherer', () => {
assert.equal(screenshots.length, 7);

const firstScreenshot = screenshots[0];
assert.ok(firstScreenshot.datauri.startsWith('data:image/jpg;base64,'));
assert.ok(firstScreenshot.datauri.startsWith('data:image/jpeg;base64,'));
assert.ok(firstScreenshot.datauri.length > 42);
});
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -171,18 +171,4 @@ describe('PerfCategoryRenderer', () => {
assert.ok(Number.isFinite(wastedMs), 'Finite number not returned by wastedMs');
});
});

describe('getFinalScreenshot', () => {
it('gets a datauri as a string', () => {
const datauri = PerformanceCategoryRenderer.getFinalScreenshot(category);
assert.equal(typeof datauri, 'string');
assert.ok(datauri.startsWith('data:image/jpeg;base64,'));
});

it('returns null if there are no screenshots', () => {
const fakeCategory = Object.assign({}, category, {auditRefs: []});
const datauri = PerformanceCategoryRenderer.getFinalScreenshot(fakeCategory);
assert.equal(datauri, null);
});
});
});
23 changes: 23 additions & 0 deletions lighthouse-core/test/report/html/renderer/util-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,10 @@

const assert = require('assert');
const Util = require('../../../../report/html/renderer/util.js');

const ReportRenderer = require('../../../../report/html/renderer/report-renderer.js');
const sampleResults = require('../../../results/sample_v2.json');

const NBSP = '\xa0';

/* eslint-env jest */
Expand Down Expand Up @@ -142,4 +146,23 @@ describe('util helpers', () => {
Util.formatDisplayValue(displayValue);
assert.deepStrictEqual(displayValue, cloned, 'displayValue was mutated');
});

describe('getFinalScreenshot', () => {
sampleResults.reportCategories = Object.values(sampleResults.categories);
const category = sampleResults.reportCategories.find(cat => cat.id === 'performance');
ReportRenderer.smooshAuditResultsIntoCategories(sampleResults.audits,
sampleResults.reportCategories);

it('gets a datauri as a string', () => {
const datauri = Util.getFinalScreenshot(category);
assert.equal(typeof datauri, 'string');
assert.ok(datauri.startsWith('data:image/jpeg;base64,'));
});

it('returns null if there are no screenshots', () => {
const fakeCategory = Object.assign({}, category, {auditRefs: []});
const datauri = Util.getFinalScreenshot(fakeCategory);
assert.equal(datauri, null);
});
});
});
2 changes: 1 addition & 1 deletion lighthouse-core/test/results/sample_v2.json
Original file line number Diff line number Diff line change
Expand Up @@ -183,7 +183,7 @@
"items": [
{
"timestamp": 185608111.383,
"data": ""
"data": ""
}
]
}
Expand Down

0 comments on commit bbb4c8b

Please sign in to comment.