summaryrefslogtreecommitdiffstats
path: root/chrome/common
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/common')
-rw-r--r--chrome/common/extensions/docs/examples/extensions/benchmark/background.html135
-rw-r--r--chrome/common/extensions/docs/examples/extensions/benchmark/options.html67
2 files changed, 153 insertions, 49 deletions
diff --git a/chrome/common/extensions/docs/examples/extensions/benchmark/background.html b/chrome/common/extensions/docs/examples/extensions/benchmark/background.html
index e31c17e..209ac5a 100644
--- a/chrome/common/extensions/docs/examples/extensions/benchmark/background.html
+++ b/chrome/common/extensions/docs/examples/extensions/benchmark/background.html
@@ -37,9 +37,56 @@ window.results.data = new Array();
window.testUrl = "";
window.windowId = 0;
+// The list of currently running benchmarks
+var benchmarks = new Array();
+var benchmarkIndex = 0;
+var benchmarkWindow = 0;
+
+function addBenchmark(benchmark) {
+ benchmarks.push(benchmark);
+}
+
+// Array Remove - By John Resig (MIT Licensed)
+Array.prototype.remove = function(from, to) {
+ var rest = this.slice((to || from) + 1 || this.length);
+ this.length = from < 0 ? this.length + from : from;
+ return this.push.apply(this, rest);
+};
+
+function removeBenchmark(benchmark) {
+ var index;
+ for (var index = 0; index < benchmarks.length; ++index) {
+ if (benchmarks[index] == benchmark) {
+ break;
+ }
+ }
+ benchmarks.remove(index);
+
+ // Preserve index ordering when removing from the list.
+ if (index <= benchmarkIndex) {
+ benchmarkIndex--; // Note: it is okay to drop to -1 here.
+ }
+}
+
+function findBenchmark(url) {
+ for (var index = 0; index < benchmarks.length; ++index) {
+ if (benchmarks[index].url() == url) {
+ return benchmarks[index];
+ }
+ }
+ return undefined;
+}
+
+function nextBenchmark() {
+ benchmarkIndex = (benchmarkIndex + 1) % benchmarks.length;
+ return benchmarks[benchmarkIndex];
+}
+
function show_options() {
chrome.tabs.getSelected(null, function(tab) {
- window.testUrl = tab.url;
+ if (window.testUrl == "") {
+ window.testUrl = tab.url;
+ }
var tabs = chrome.extension.getExtensionTabs();
if (tabs && tabs.length) {
tabs[0].setUrl(testUrl);
@@ -64,7 +111,6 @@ function Benchmark() {
var runCount_ = 0;
var count_;
var totalTime_;
- var lastWin_;
var me_ = this;
var current_;
var initialReadBytes_;
@@ -77,22 +123,23 @@ function Benchmark() {
return;
}
- console.log("Starting test for url: " + url);
+ console.log("Benchmark testing url: " + url);
+
+ // Add this benchmark to the list of benchmarks running.
+ addBenchmark(this);
runCount_ = window.iterations;
count_ = 0;
totalTime_ = 0;
- lastWin_ = 0;
current_ = {};
current_.url = url;
current_.docLoadResults = new Array(); // times to docload
current_.paintResults = new Array(); // times to paint
current_.totalResults = new Array(); // times to complete load
- initialReadBytes = chrome.benchmarking.counter("tcp.read_bytes");
- initialWriteBytes = chrome.benchmarking.counter("tcp.write_bytes");
-
- me_.runPage();
+ current_.bytesRead = 0;
+ current_.bytesWritten = 0;
+ current_.totalTime = 0;
}
// Is the benchmark currently in progress.
@@ -100,21 +147,23 @@ function Benchmark() {
return runCount_ > 0;
}
+ // The url which this benchmark is running.
+ this.url = function() { return current_.url; }
+
// Called when the test run completes.
this.finish = function() {
- chrome.tabs.remove(lastWin_.id);
- lastWin_ = 0;
-
- // Record some more stats.
- current_.bytesRead = chrome.benchmarking.counter("tcp.read_bytes") -
- initialReadBytes;
- current_.bytesWritten = chrome.benchmarking.counter("tcp.write_bytes") -
- initialWriteBytes;
- current_.totalTime = totalTime_;
+ removeBenchmark(this);
- // push the result
+ // Push the result.
window.results.data.push(current_);
- current_ = 0;
+
+ // If we're the last benchmark, close the window.
+ if (benchmarks.length == 0) {
+ chrome.tabs.remove(benchmarkWindow.id);
+ benchmarkWindow = 0;
+
+ show_options();
+ }
}
// Update the UI after a test run.
@@ -143,15 +192,21 @@ function Benchmark() {
if (window.clearCache) {
chrome.benchmarking.clearCache();
}
+
if (window.clearConnections) {
chrome.benchmarking.closeConnections();
}
- if (lastWin_) {
- chrome.tabs.update(lastWin_.id, {"url": current_.url});
+ initialReadBytes = chrome.benchmarking.counter("tcp.read_bytes");
+ initialWriteBytes = chrome.benchmarking.counter("tcp.write_bytes");
+
+
+ if (benchmarkWindow) {
+ var benchmark = nextBenchmark();
+ chrome.tabs.update(benchmarkWindow.id, {"url": benchmark.url() });
} else {
- chrome.tabs.create({"url": current_.url},
- function(tab) { lastWin_ = tab; });
+ chrome.tabs.create({"url": current_.url },
+ function(tab) { benchmarkWindow = tab; });
}
}
@@ -164,32 +219,46 @@ function Benchmark() {
var totalTime =
Math.round((csi.finishLoadTime - csi.startLoadTime) * 1000.0);
+ if (paintTime < 0) {
+ // If the user navigates away from the test while it is running,
+ // paint may not occur.
+ alert("No paint detected. Did you navigate while the test was running?");
+ paintTime = totalTime; // approximate.
+ }
+
+ // For our toolbar counters
+ totalTime_ += totalTime;
+ count_++;
+
// Record the result
current_.docLoadResults.push(docLoadTime);
current_.paintResults.push(paintTime);
current_.totalResults.push(totalTime);
+ current_.bytesRead += chrome.benchmarking.counter("tcp.read_bytes") -
+ initialReadBytes;
+ current_.bytesWritten += chrome.benchmarking.counter("tcp.write_bytes") -
+ initialWriteBytes;
+ current_.totalTime += totalTime;
- // For our toolbar counters
- totalTime_ += totalTime;
- count_++;
+ if (--runCount_ == 0) {
+ me_.finish();
+ }
- if (--runCount_ > 0) {
+ // If there are more tests, schedule them
+ if (runCount_ > 0 || benchmarks.length > 0) {
setTimeout(me_.runPage, 100);
- } else {
- me_.finish();
}
// Update the UI
me_.displayResults();
+
}
}
-var benchmarks = new Array();
-
chrome.extension.onConnect.addListener(function(port) {
port.onMessage.addListener(function(data) {
if (data.message == "load") {
- var benchmark = benchmarks[data.url];
+ var benchmark = findBenchmark(data.url);
if (benchmark != undefined && benchmark.isRunning()) {
benchmark.pageFinished(data.values);
}
@@ -201,9 +270,9 @@ function run() {
var urls = testUrl.split(",");
for (var i = 0; i < urls.length; i++) {
var benchmark = new Benchmark();
- benchmarks[urls[i]] = benchmark;
benchmark.start(urls[i]); // XXXMB - move to constructor
}
+ benchmarks[0].runPage();
}
// Run at startup
diff --git a/chrome/common/extensions/docs/examples/extensions/benchmark/options.html b/chrome/common/extensions/docs/examples/extensions/benchmark/options.html
index 99a7dcd..4df1db3 100644
--- a/chrome/common/extensions/docs/examples/extensions/benchmark/options.html
+++ b/chrome/common/extensions/docs/examples/extensions/benchmark/options.html
@@ -118,7 +118,7 @@ Array.avg = function(array) {
sum = sum - min - max;
count -= 2;
}
- return (sum / count).toFixed(1);
+ return sum / count;
}
// Compute the standard deviation of an array
@@ -134,21 +134,41 @@ Array.stddev = function(array) {
return Math.sqrt(variance).toFixed(2);
}
+// Object to summarize everything
+var totals = {};
+
// Computes min/max/mean/stddev, etc all up front.
function computeResults(data) {
- for (var i = 0; i < data.data.length; i++) {
+ totals = {};
+ totals.mean = 0;
+ totals.paintMean = 0;
+ totals.docLoadMean = 0;
+
+ var count = data.data.length;
+ for (var i = 0; i < count; i++) {
var obj = data.data[i];
var resultList = obj.totalResults;
obj.mean = Array.avg(resultList);
obj.stddev = Array.stddev(resultList);
obj.min = Array.min(resultList);
obj.max = Array.max(resultList);
- obj.readbps = (obj.bytesRead * 8 / obj.totalTime).toFixed(2);
- obj.writebps = (obj.bytesWritten * 8 / obj.totalTime).toFixed(2);
- obj.readKB = (obj.bytesRead / 1024).toFixed(0);
- obj.writeKB = (obj.bytesWritten / 1024).toFixed(0);
+ obj.readbps = obj.bytesRead * 8 / obj.totalTime;
+ obj.writebps = obj.bytesWritten * 8 / obj.totalTime;
+ obj.readKB = obj.bytesRead / 1024;
+ obj.writeKB = obj.bytesWritten / 1024;
obj.paintMean = Array.avg(obj.paintResults);
obj.docLoadMean = Array.avg(obj.docLoadResults);
+
+ totals.mean += obj.mean;
+ totals.paintMean += obj.paintMean;
+ totals.docLoadMean += obj.docLoadMean;
+ }
+
+ totals.url = "(" + count + " urls)";
+ if (count > 0) {
+ totals.mean /= count;
+ totals.paintMean /= count;
+ totals.docLoadMean /= count;
}
// Find the biggest sample for our bar graph.
@@ -258,18 +278,33 @@ Clear Cache?<input id="clearcache" type="checkbox">
<th samples</th>
</tr>
+ <tr id="t.total" jsselect="totals">
+ <td class="url">TOTALS <span jscontent="url"></span></td>
+ <td class="avg"><span jseval="val = docLoadMean.toFixed(1)" jscontent="val"></span></td>
+ <td class="avg"><span jseval="val = paintMean.toFixed(1)" jscontent="val"></span></td>
+ <td class="avg"><span jseval="val = mean.toFixed(1)" jscontent="val"></span></td>
+ <td class="avg" jseval="1"></td>
+ <td class="avg" jseval="1"></td>
+ <td class="avg" jseval="1"></td>
+ <td class="avg" jseval="1"></td>
+ <td class="avg" jseval="1"></td>
+ <td class="avg" jseval="1"></td>
+ <td class="avg" jseval="1"></td>
+ <td class="data"></td>
+ </tr>
+
<tr jsselect="data">
<td class="url" jseval="$width = getWidth($this.mean, 600)"><div jsvalues=".style.width:$width" class="bggraph"><a jsvalues="href:$this.url" jscontent="url"></a></div></td>
- <td class="avg" jscontent="docLoadMean"></td>
- <td class="avg" jscontent="paintMean"></td>
- <td class="avg" jscontent="mean"></td>
- <td class="avg" jscontent="stddev"></td>
- <td class="avg" jscontent="min"></td>
- <td class="avg" jscontent="max"></td>
- <td class="avg" jscontent="readKB"></td>
- <td class="avg" jscontent="writeKB"></td>
- <td class="avg" jscontent="readbps"></td>
- <td class="avg" jscontent="writebps"></td>
+ <td class="avg" jseval="val = docLoadMean.toFixed(1)" jscontent="val"></td>
+ <td class="avg" jseval="val = paintMean.toFixed(1)" jscontent="val"></td>
+ <td class="avg" jseval="val = mean.toFixed(1)" jscontent="val"></td>
+ <td class="avg" jseval="val = stddev.toFixed(1)" jscontent="val"></td>
+ <td class="avg" jseval="val = min.toFixed(1)" jscontent="val"></td>
+ <td class="avg" jseval="val = max.toFixed(1)" jscontent="val"></td>
+ <td class="avg" jseval="val = readKB.toFixed(1)" jscontent="val"></td>
+ <td class="avg" jseval="val = writeKB.toFixed(1)" jscontent="val"></td>
+ <td class="avg" jseval="val = readbps.toFixed(1)" jscontent="val"></td>
+ <td class="avg" jseval="val = writebps.toFixed(1)" jscontent="val"></td>
<td class="data"><span jsselect="totalResults"><span jscontent="$this"></span>,</span> </td>
</tr>
<tr jsdisplay="data.length == 0">