Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

core: Optimize asynchronous task executions ✈ #15715

Open
wants to merge 4 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 4 additions & 2 deletions core/audits/script-treemap-data.js
Original file line number Diff line number Diff line change
Expand Up @@ -167,8 +167,10 @@ class ScriptTreemapDataAudit extends Audit {
const nodes = [];
/** @type {Map<string, LH.Treemap.Node>} */
const htmlNodesByFrameId = new Map();
const bundles = await JSBundles.request(artifacts, context);
const duplicationByPath = await ModuleDuplication.request(artifacts, context);
const [bundles, duplicationByPath] = await Promise.all([
JSBundles.request(artifacts, context),
ModuleDuplication.request(artifacts, context),
]);

sanjaiyan-dev marked this conversation as resolved.
Show resolved Hide resolved
for (const script of artifacts.Scripts) {
if (script.scriptLanguage !== 'JavaScript') continue;
Expand Down
6 changes: 4 additions & 2 deletions core/computed/metrics/time-to-first-byte.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,10 @@ class TimeToFirstByte extends NavigationMetric {
* @return {Promise<LH.Artifacts.Metric>}
*/
static async computeSimulatedMetric(data, context) {
const mainResource = await MainResource.request(data, context);
const networkAnalysis = await NetworkAnalysis.request(data.devtoolsLog, context);
const [mainResource, networkAnalysis] = await Promise.all([
MainResource.request(data, context),
NetworkAnalysis.request(data.devtoolsLog, context),
]);
sanjaiyan-dev marked this conversation as resolved.
Show resolved Hide resolved

const observedTTFB = (await this.computeObservedMetric(data, context)).timing;
const observedResponseTime =
Expand Down
6 changes: 4 additions & 2 deletions core/computed/tbt-impact-tasks.js
Original file line number Diff line number Diff line change
Expand Up @@ -39,8 +39,10 @@ class TBTImpactTasks {
};
}

const fcpResult = await FirstContentfulPaint.request(metricComputationData, context);
const ttiResult = await Interactive.request(metricComputationData, context);
const [fcpResult, ttiResult] = await Promise.all([
FirstContentfulPaint.request(metricComputationData, context),
Interactive.request(metricComputationData, context),
]);
sanjaiyan-dev marked this conversation as resolved.
Show resolved Hide resolved

let startTimeMs = fcpResult.timing;
let endTimeMs = ttiResult.timing;
Expand Down
6 changes: 4 additions & 2 deletions core/gather/base-artifacts.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,10 @@ import {
* @return {Promise<LH.BaseArtifacts>}
*/
async function getBaseArtifacts(resolvedConfig, driver, context) {
const BenchmarkIndex = await getBenchmarkIndex(driver.executionContext);
const {userAgent, product} = await getBrowserVersion(driver.defaultSession);
const [BenchmarkIndex, {userAgent, product}] = await Promise.all([
getBenchmarkIndex(driver.executionContext),
getBrowserVersion(driver.defaultSession),
]);

sanjaiyan-dev marked this conversation as resolved.
Show resolved Hide resolved
return {
// Meta artifacts.
Expand Down
6 changes: 4 additions & 2 deletions core/gather/gatherers/link-elements.js
Original file line number Diff line number Diff line change
Expand Up @@ -177,8 +177,10 @@ class LinkElements extends BaseGatherer {
*/
async getArtifact(context) {
const devtoolsLog = context.dependencies.DevtoolsLog;
const fromDOM = await LinkElements.getLinkElementsInDOM(context);
const fromHeaders = await LinkElements.getLinkElementsInHeaders(context, devtoolsLog);
const [fromDOM, fromHeaders] = await Promise.all([
LinkElements.getLinkElementsInDOM(context),
LinkElements.getLinkElementsInHeaders(context, devtoolsLog),
]);
const linkElements = fromDOM.concat(fromHeaders);
sanjaiyan-dev marked this conversation as resolved.
Show resolved Hide resolved

for (const link of linkElements) {
Expand Down
6 changes: 4 additions & 2 deletions core/gather/gatherers/service-worker.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,10 @@
*/
async getArtifact(context) {
const session = context.driver.defaultSession;
const {versions} = await serviceWorkers.getServiceWorkerVersions(session);
const {registrations} = await serviceWorkers.getServiceWorkerRegistrations(session);
const [{versions}, {registrations}] = await Promise.all([
serviceWorkers.getServiceWorkerVersions(session),
serviceWorkers.getServiceWorkerRegistrations(session),
]);

Check warning on line 25 in core/gather/gatherers/service-worker.js

View check run for this annotation

Codecov / codecov/patch

core/gather/gatherers/service-worker.js#L22-L25

Added lines #L22 - L25 were not covered by tests
sanjaiyan-dev marked this conversation as resolved.
Show resolved Hide resolved

return {
versions,
Expand Down
Loading