blob: 33ad36eaeafa6c2a7b6a419a77c19f821c6055a4 [file] [log] [blame]
Avi Drissmane4622aa2022-09-08 20:36:061// Copyright 2018 The Chromium Authors
Alexei Filippov0a57e5d2018-05-23 18:13:552// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5// To benchmark a specific version of Chrome set the CHROME_PATH environment
6// variable, e.g.:
Alexei Filippov0bed5b242018-07-04 02:08:387// $ CHROME_PATH=~/chromium/src/out/Release/chrome node benchmark-octane.js
Alexei Filippov0a57e5d2018-05-23 18:13:558
9const puppeteer = require('puppeteer');
10
Alexei Filippov0a57e5d2018-05-23 18:13:5511async function runOctane(samplingRate) {
12 const args = ['--enable-devtools-experiments'];
13 if (samplingRate)
Alexei Filippov6e5864282019-04-26 23:26:5114 args.push(`--memlog=all`, `--memlog-sampling-rate=${samplingRate}`);
Alexei Filippov0bed5b242018-07-04 02:08:3815 while (true) {
Alexei Filippov6e5864282019-04-26 23:26:5116 let browser;
Alexei Filippov0bed5b242018-07-04 02:08:3817 try {
18 browser = await puppeteer.launch({
19 executablePath: process.env.CHROME_PATH, args, headless: true});
20 const page = await browser.newPage();
21 await page.goto('https://chromium.github.io/octane/');
22 await page.waitForSelector('#run-octane'); // Just in case.
23 await page.click('#run-octane');
Alexei Filippov0a57e5d2018-05-23 18:13:5524
Alexei Filippov0bed5b242018-07-04 02:08:3825 const scoreDiv = await page.waitForSelector('#main-banner:only-child',
26 {timeout: 120000});
27 const scoreText = await page.evaluate(e => e.innerText, scoreDiv);
28 const match = /Score:\s*(\d+)/.exec(scoreText);
29 if (match.length < 2)
30 continue;
31 return parseInt(match[1]);
32 } finally {
33 if (browser)
34 await browser.close();
Alexei Filippov0a57e5d2018-05-23 18:13:5535 }
Alexei Filippov0a57e5d2018-05-23 18:13:5536 }
37}
38
Alexei Filippov0bed5b242018-07-04 02:08:3839async function makeRuns(rates) {
40 const scores = [];
41 for (const rate of rates)
42 scores.push(await runOctane(rate));
43 console.log(scores.join('\t'));
Alexei Filippov0a57e5d2018-05-23 18:13:5544}
45
46async function main() {
47 console.log(`Using ${process.env.CHROME_PATH || puppeteer.executablePath()}`);
Alexei Filippov0bed5b242018-07-04 02:08:3848 const rates = [0];
49 for (let rate = 8; rate <= 2048; rate *= 2)
50 rates.push(rate);
51 console.log('Rates [KB]:');
52 console.log(rates.join('\t'));
53 console.log('='.repeat(rates.length * 8));
54 for (let i = 0; i < 100; ++i)
55 await makeRuns(rates);
Alexei Filippov0a57e5d2018-05-23 18:13:5556}
57
58main();