summaryrefslogtreecommitdiffstats
path: root/Source/WebCore/manual-tests/database-threading-stress-test.html
diff options
context:
space:
mode:
authorSteve Block <steveblock@google.com>2011-05-06 11:45:16 +0100
committerSteve Block <steveblock@google.com>2011-05-12 13:44:10 +0100
commitcad810f21b803229eb11403f9209855525a25d57 (patch)
tree29a6fd0279be608e0fe9ffe9841f722f0f4e4269 /Source/WebCore/manual-tests/database-threading-stress-test.html
parent121b0cf4517156d0ac5111caf9830c51b69bae8f (diff)
downloadexternal_webkit-cad810f21b803229eb11403f9209855525a25d57.zip
external_webkit-cad810f21b803229eb11403f9209855525a25d57.tar.gz
external_webkit-cad810f21b803229eb11403f9209855525a25d57.tar.bz2
Merge WebKit at r75315: Initial merge by git.
Change-Id: I570314b346ce101c935ed22a626b48c2af266b84
Diffstat (limited to 'Source/WebCore/manual-tests/database-threading-stress-test.html')
-rw-r--r--Source/WebCore/manual-tests/database-threading-stress-test.html84
1 files changed, 84 insertions, 0 deletions
diff --git a/Source/WebCore/manual-tests/database-threading-stress-test.html b/Source/WebCore/manual-tests/database-threading-stress-test.html
new file mode 100644
index 0000000..f22610c
--- /dev/null
+++ b/Source/WebCore/manual-tests/database-threading-stress-test.html
@@ -0,0 +1,84 @@
+<!doctype html>
+<html>
+<head>
+
+<style>
+pre { padding: 5px; border: 1px solid black; }
+</style>
+
+<script>
+var db;
+
+try {
+ if (window.openDatabase) {
+ db = openDatabase("StressTest1", "1.0", "Database Stress Test", 200000);
+ if (!db)
+ alert("Failed to open the database on disk. This is probably because the version was bad or there is not enough space left in this domain's quota");
+ } else
+ alert("Couldn't open the database.");
+} catch(err) { }
+
+var highestId = 0;
+var allData = new Array();
+
+function newData()
+{
+ var id = ++highestId;
+ allData.push(id);
+ db.transaction(function (tx)
+ {
+ tx.executeSql("INSERT INTO FillerData (id, filler) VALUES (?, randomblob(1024))", [id]);
+ });
+}
+
+function testOpen()
+{
+ for (var i = 0; i < 4; i++) {
+ newData();
+ }
+
+ setTimeout("testClose();", 0);
+}
+
+function testClose()
+{
+ db.transaction(function(tx)
+ {
+ for (var i = 0; i < allData.length; i++)
+ tx.executeSql("DELETE FROM FillerData WHERE id = ?", [allData[i]]);
+
+ allData = new Array();
+ });
+ setTimeout("testOpen();", 0);
+}
+
+function updateTransactionCount()
+{
+ document.getElementById("transactionCount").innerHTML = "Current Transaction Count: " + highestId;
+ setTimeout("updateTransactionCount();", 1000);
+}
+
+function loaded()
+{
+ db.transaction(function(tx) {
+ tx.executeSql("SELECT COUNT(*) FROM FillerData", [], function(result) { }, function(tx, error) {
+ tx.executeSql("CREATE TABLE FillerData (id REAL UNIQUE, filler)", [], function(result) {
+ });
+ });
+ });
+
+ setTimeout("testOpen();", 0);
+ setTimeout("updateTransactionCount();", 1000);
+}
+
+addEventListener('load', loaded, false);
+</script>
+</head>
+
+<body>
+This test stresses the database threading code by constantly opening transactions to the test database at a fast rate.<br>
+See radar 5729446 for more details.<br>
+<pre id="transactionCount">Current Transaction Count: 0</pre>
+
+</body>
+</html>