Index: LayoutTests/inspector/storage-panel-dom-storage-undo-redo.html |
diff --git a/LayoutTests/inspector/storage-panel-dom-storage-undo-redo.html b/LayoutTests/inspector/storage-panel-dom-storage-undo-redo.html |
new file mode 100644 |
index 0000000000000000000000000000000000000000..1412ef660172d75d074637b9a283367d941157bd |
--- /dev/null |
+++ b/LayoutTests/inspector/storage-panel-dom-storage-undo-redo.html |
@@ -0,0 +1,339 @@ |
+<html> |
+<head> |
+<script src="../http/tests/inspector/inspector-test.js"></script> |
+<script> |
+ |
+function clearDOMStorage() |
+{ |
+ localStorage.clear(); |
+ sessionStorage.clear(); |
+} |
+ |
+function getDOMStorageEntries(isLocalStorage) |
+{ |
+ var storage = isLocalStorage ? localStorage : sessionStorage; |
+ var entries = []; |
+ for (var i = 0; i < storage.length; ++i) { |
+ var key = storage.key(i); |
+ var value = storage.getItem(key); |
+ entries.push(key + "=" + value); |
+ } |
+ entries.sort(); |
+ return "[" + entries.join() + "]"; |
+} |
+ |
+function test() |
+{ |
+ WebInspector.DOMStorageHistory.MAX_UNDO_STACK_DEPTH = 20; |
+ |
+ WebInspector.showPanel("resources"); |
+ |
+ var theLocalStorage; |
+ var theSessionStorage; |
+ var storages = WebInspector.domStorageModel.storages(); |
+ for (var i = 0; i < storages.length; ++i) { |
+ var storage = storages[i]; |
+ if (storage.isLocalStorage) |
+ theLocalStorage = storage; |
+ else |
+ theSessionStorage = storage; |
+ } |
+ |
+ function dumpDOMStorage(next) |
+ { |
+ if (this.isLocalStorage) |
+ InspectorTest.evaluateInPage("getDOMStorageEntries(true)", storageEntriesReceived.bind(this)); |
+ else |
+ InspectorTest.evaluateInPage("getDOMStorageEntries(false)", storageEntriesReceived.bind(this)); |
+ |
+ function storageEntriesReceived(entries) |
+ { |
+ InspectorTest.addResult((this.isLocalStorage ? "LocalStorage" : "SessionStorage") + " contents:" + entries.description); |
+ next(); |
+ } |
+ } |
+ |
+ function show(storage) |
+ { |
+ WebInspector.panels.resources._showDOMStorage(storage); |
+ } |
+ |
+ function undo(operations, next) |
+ { |
+ for (var i = 0; i < operations; ++i) |
+ this.undo(); |
+ InspectorTest.runAfterPendingDispatches(dumpDOMStorage.bind(this, next)); |
+ } |
+ |
+ function redo(operations, next) |
+ { |
+ for (var i = 0; i < operations; ++i) |
+ this.redo(); |
+ InspectorTest.runAfterPendingDispatches(dumpDOMStorage.bind(this, next)); |
+ } |
+ |
+ function addKeyValuePair(storage, key, value) |
+ { |
+ var dataGrid = WebInspector.panels.resources._domStorageViews.get(storage)._dataGrid; |
+ var creationNode = dataGrid.rootNode().children.peekLast(); |
+ |
+ var elementKey = creationNode._element.children[0]; |
+ dataGrid._startEditing(elementKey); |
+ elementKey.textContent = key; |
+ elementKey.dispatchEvent(InspectorTest.createKeyEvent("Enter")); |
+ |
+ var elementValue = creationNode._element.children[1]; |
+ dataGrid._startEditing(elementValue); |
+ elementValue.textContent = value; |
+ elementValue.dispatchEvent(InspectorTest.createKeyEvent("Enter")); |
+ } |
+ |
+ function modifyValueForKey(storage, key, newValue) |
+ { |
+ var dataGrid = WebInspector.panels.resources._domStorageViews.get(storage)._dataGrid; |
+ var children = dataGrid.rootNode().children; |
+ |
+ var modificationNode; |
+ for (var i = 0; i < children.length; ++i) { |
+ if (children[i]._element.children[0].textContent === key) { |
+ modificationNode = children[i]; |
+ break; |
+ } |
+ } |
+ |
+ var elementValue = modificationNode._element.children[1]; |
+ dataGrid._startEditing(elementValue); |
+ elementValue.textContent = newValue; |
+ elementValue.dispatchEvent(InspectorTest.createKeyEvent("Enter")); |
+ } |
+ |
+ function changeKey(storage, oldKey, newKey) |
+ { |
+ var dataGrid = WebInspector.panels.resources._domStorageViews.get(storage)._dataGrid; |
+ var children = dataGrid.rootNode().children; |
+ |
+ var modificationNode; |
+ for (var i = 0; i < children.length; ++i) { |
+ if (children[i]._element.children[0].textContent === oldKey) { |
+ modificationNode = children[i]; |
+ break; |
+ } |
+ } |
+ var elementKey = modificationNode._element.children[0]; |
+ dataGrid._startEditing(elementKey); |
+ elementKey.textContent = newKey; |
+ elementKey.dispatchEvent(InspectorTest.createKeyEvent("Enter")); |
+ } |
+ |
+ InspectorTest.runTestSuite([ |
+ function initialize(next) |
+ { |
+ InspectorTest.evaluateInPage("clearDOMStorage()", initialized); |
+ |
+ function initialized(result) |
+ { |
+ InspectorTest.addResult("Initialized localStorage and sessionStorage by clearing entries."); |
+ next(); |
+ } |
+ }, |
+ |
+ function undoLocalStorageWithEmptyStack(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theLocalStorage, 10, next)); |
+ }, |
+ |
+ function redoLocalStorageWithEmptyStack(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(redo.bind(theLocalStorage, 10, next)); |
+ }, |
+ |
+ function localStorageUndoInterlacedWithAddition(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(domStorageViewShown.bind(theLocalStorage)); |
+ function domStorageViewShown() |
+ { |
+ addKeyValuePair(this, "a1", "b1"); |
+ addKeyValuePair(this, "a2", "b2"); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theLocalStorage, 2, firstUndoDone.bind(null, next))); |
+ |
+ function firstUndoDone(callback) |
+ { |
+ addKeyValuePair(theLocalStorage, "a3", "b3"); |
+ InspectorTest.runAfterPendingDispatches(dumpDOMStorage.bind(theLocalStorage, nextUndoDone.bind(null, callback))); |
+ |
+ function nextUndoDone(callback) |
+ { |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theLocalStorage, 2, callback)); |
+ } |
+ } |
+ } |
+ }, |
+ |
+ function addLocalStorageEntries(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(domStorageViewShown.bind(theLocalStorage)); |
+ |
+ function domStorageViewShown() |
+ { |
+ addKeyValuePair(this, "a1", "b1"); |
+ addKeyValuePair(this, "a2", "b2"); |
+ InspectorTest.runAfterPendingDispatches(dumpDOMStorage.bind(this, next)); |
+ } |
+ }, |
+ |
+ function undoLocalStorageLastAddition(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theLocalStorage, 2, next)); |
+ }, |
+ |
+ function undoSessionStorageWithEmptyStack(next) |
+ { |
+ show(theSessionStorage); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theSessionStorage, 10, next)); |
+ }, |
+ |
+ function redoSessionStorageWithEmptyStack(next) |
+ { |
+ show(theSessionStorage); |
+ InspectorTest.runAfterPendingDispatches(redo.bind(theSessionStorage, 10, next)); |
+ }, |
+ |
+ function undoLocalStorageBeyondBounds(next) |
+ { |
+ InspectorTest.addResult("The entry a1=b1 is removed and any attempt to undo beyond it shouldn't cause any failure!") |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theLocalStorage, 10, next)); |
+ }, |
+ |
+ function addSessionStorageEntries(next) |
+ { |
+ show(theSessionStorage); |
+ InspectorTest.runAfterPendingDispatches(domStorageViewShown.bind(theSessionStorage)); |
+ |
+ function domStorageViewShown() |
+ { |
+ addKeyValuePair(this, "p1", "q1"); |
+ addKeyValuePair(this, "p2", "q2"); |
+ addKeyValuePair(this, "p3", "q3"); |
+ addKeyValuePair(this, "p4", "q4"); |
+ InspectorTest.runAfterPendingDispatches(dumpDOMStorage.bind(this, next)); |
+ } |
+ }, |
+ |
+ function redoLocalStorageBeyondBounds(next) |
+ { |
+ InspectorTest.addResult("The entry a1=b1 and a2=b2 is added back and any attempt to redo beyond it shouldn't cause any failure!") |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(redo.bind(theLocalStorage, 10, next)); |
+ }, |
+ |
+ function undoSessionStorageLastAddition(next) |
+ { |
+ show(theSessionStorage); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theSessionStorage, 2, next)); |
+ }, |
+ |
+ function modifyLocalStorageValues(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(domStorageViewShown.bind(theLocalStorage)); |
+ |
+ function domStorageViewShown() |
+ { |
+ modifyValueForKey(this, "a1", "x1"); |
+ modifyValueForKey(this, "a2", "x2"); |
+ InspectorTest.runAfterPendingDispatches(dumpDOMStorage.bind(this, next)); |
+ } |
+ }, |
+ |
+ function undoLocalStorageModifications(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theLocalStorage, 2, next)); |
+ }, |
+ |
+ function redoSessionStorageLastAddition(next) |
+ { |
+ show(theSessionStorage); |
+ InspectorTest.runAfterPendingDispatches(redo.bind(theSessionStorage, 2, next)); |
+ }, |
+ |
+ function redoLocalStorageModifications(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(redo.bind(theLocalStorage, 2, next)); |
+ }, |
+ |
+ function modifySessionStorageEntriesKey(next) |
+ { |
+ show(theSessionStorage); |
+ InspectorTest.runAfterPendingDispatches(domStorageViewShown.bind(theSessionStorage)); |
+ |
+ function domStorageViewShown() |
+ { |
+ changeKey(this, "p1", "m1"); |
+ changeKey(this, "p2", "m2"); |
+ changeKey(this, "p3", "m3"); |
+ changeKey(this, "p4", "m4"); |
+ InspectorTest.runAfterPendingDispatches(dumpDOMStorage.bind(this, next)); |
+ } |
+ }, |
+ |
+ function undoLocalStorageModifications(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theLocalStorage, 2, next)); |
+ }, |
+ |
+ function undoSessionStorageKeyModifications(next) |
+ { |
+ show(theSessionStorage); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theSessionStorage, 8, next)); |
+ }, |
+ |
+ function validateMaxUndoRedoStackDepth(next) |
+ { |
+ show(theLocalStorage); |
+ InspectorTest.runAfterPendingDispatches(domStorageViewShown.bind(theLocalStorage)); |
+ |
+ function domStorageViewShown() |
+ { |
+ var stackDepth = WebInspector.DOMStorageHistory.MAX_UNDO_STACK_DEPTH; |
+ InspectorTest.addResult("Undo/redo stack depth limit is " + stackDepth); |
+ InspectorTest.addResult("Performing " + (2 * stackDepth) + " actions"); |
+ for (var i = 1; i <= stackDepth; ++i) |
+ addKeyValuePair(this, "x" + i, "y" + i); |
+ |
+ InspectorTest.runAfterPendingDispatches(dumpDOMStorage.bind(this, undoMoreThanDepth)); |
+ |
+ function undoMoreThanDepth() |
+ { |
+ InspectorTest.addResult("Performing undo operation three times the depth i.e. " + (3 * stackDepth) + " times but only last " + stackDepth + " operations are undone"); |
+ InspectorTest.runAfterPendingDispatches(undo.bind(theLocalStorage, (3 * stackDepth), next)); |
+ } |
+ } |
+ }, |
+ |
+ function clearDOMStorageAndFinish(next) |
+ { |
+ InspectorTest.evaluateInPage("clearDOMStorage()", finishTest); |
+ |
+ function finishTest(result) |
+ { |
+ InspectorTest.addResult("Finished DOMStorage undo/redo tests and cleared localStorage and sessionStorage entries."); |
+ next(); |
+ } |
+ } |
+ ]); |
+} |
+</script> |
+</head> |
+<body onload="runTest()"> |
+<p>This test checks the undo/redo operations are performed correctly on the DOM storage views</p> |
+</body> |
+</html> |