Bug 1252099 - Do not use CPOWs in browser_markup_copy_image_data.js; r=jdescottes
authorPatrick Brosset <pbrosset@mozilla.com>
Tue, 01 Mar 2016 14:13:46 +0100
changeset 322551 a0a0d58ed79e32048d1feb1c9a523e61884862e7
parent 322550 31134c5883ffc553569907de14daa72fc08dbae6
child 322552 252119bf3b6d1c725895b9d6af029519ab9398f2
push id5913
push userjlund@mozilla.com
push dateMon, 25 Apr 2016 16:57:49 +0000
treeherdermozilla-beta@dcaf0a6fa115 [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
reviewersjdescottes
bugs1252099
milestone47.0a1
first release with
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
last release without
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
Bug 1252099 - Do not use CPOWs in browser_markup_copy_image_data.js; r=jdescottes MozReview-Commit-ID: KWQMPplwIY8
devtools/client/inspector/markup/test/browser.ini
devtools/client/inspector/markup/test/browser_markup_copy_image_data.js
devtools/client/inspector/markup/test/doc_markup_image_and_canvas.html
devtools/client/shared/test/test-actor.js
--- a/devtools/client/inspector/markup/test/browser.ini
+++ b/devtools/client/inspector/markup/test/browser.ini
@@ -8,16 +8,17 @@ support-files =
   doc_markup_dragdrop_autoscroll.html
   doc_markup_edit.html
   doc_markup_events.html
   doc_markup_events_form.html
   doc_markup_events_jquery.html
   doc_markup_events-overflow.html
   doc_markup_flashing.html
   doc_markup_html_mixed_case.html
+  doc_markup_image_and_canvas.html
   doc_markup_links.html
   doc_markup_mutation.html
   doc_markup_navigation.html
   doc_markup_not_displayed.html
   doc_markup_pagesize_01.html
   doc_markup_pagesize_02.html
   doc_markup_search.html
   doc_markup_svg_attributes.html
--- a/devtools/client/inspector/markup/test/browser_markup_copy_image_data.js
+++ b/devtools/client/inspector/markup/test/browser_markup_copy_image_data.js
@@ -2,110 +2,86 @@
 /* Any copyright is dedicated to the Public Domain.
  http://creativecommons.org/publicdomain/zero/1.0/ */
 
 "use strict";
 
 // Test that image nodes have the "copy data-uri" contextual menu item enabled
 // and that clicking it puts the image data into the clipboard
 
-const PAGE_CONTENT = [
-  '<div></div>',
-  '<img class="data" src="" />',
-  '<canvas class="canvas" width="600" height="600"></canvas>'
-].join("\n");
-
 add_task(function*() {
-  yield addTab("data:text/html,markup view copy image as data-uri");
-  createDocument();
-  let doc = content.document;
-
-  let {inspector} = yield openInspector();
+  yield addTab(URL_ROOT + "doc_markup_image_and_canvas.html");
+  let {inspector, testActor} = yield openInspector();
 
   yield selectNode("div", inspector);
   yield assertCopyImageDataNotAvailable(inspector);
 
   yield selectNode("img", inspector);
   yield assertCopyImageDataAvailable(inspector);
-  yield triggerCopyImageUrlAndWaitForClipboard(doc.querySelector("img").src, inspector);
+  let expectedSrc = yield testActor.getAttribute("img", "src");
+  yield triggerCopyImageUrlAndWaitForClipboard(expectedSrc, inspector);
 
   yield selectNode("canvas", inspector);
   yield assertCopyImageDataAvailable(inspector);
-  let canvas = doc.querySelector(".canvas");
-  yield triggerCopyImageUrlAndWaitForClipboard(canvas.toDataURL(), inspector);
+  let expectedURL = yield testActor.eval(`
+    content.document.querySelector(".canvas").toDataURL();`);
+  yield triggerCopyImageUrlAndWaitForClipboard(expectedURL, inspector);
 
   // Check again that the menu isn't available on the DIV (to make sure our
   // menu updating mechanism works)
   yield selectNode("div", inspector);
   yield assertCopyImageDataNotAvailable(inspector);
 });
 
-function createDocument() {
-  let doc = content.document;
+function* assertCopyImageDataNotAvailable(inspector) {
+  let menu = yield openNodeMenu(inspector);
 
-  doc.body.innerHTML = PAGE_CONTENT;
-  let context = doc.querySelector(".canvas").getContext("2d");
-  context.beginPath();
-  context.moveTo(300, 0);
-  context.lineTo(600, 600);
-  context.lineTo(0, 600);
-  context.closePath();
-  context.fillStyle = "#ffc821";
-  context.fill();
-}
+  let item = menu.getElementsByAttribute("id", "node-menu-copyimagedatauri")[0];
+  ok(item, "The menu item was found in the contextual menu");
+  is(item.getAttribute("disabled"), "true", "The menu item is disabled");
 
-function assertCopyImageDataNotAvailable(inspector) {
-  return openNodeMenu(inspector).then(menu => {
-    let item = menu.getElementsByAttribute("id", "node-menu-copyimagedatauri")[0];
-    ok(item, "The menu item was found in the contextual menu");
-    is(item.getAttribute("disabled"), "true", "The menu item is disabled");
-  }).then(() => closeNodeMenu(inspector));
+  yield closeNodeMenu(inspector);
 }
 
-function assertCopyImageDataAvailable(inspector) {
-  return openNodeMenu(inspector).then(menu => {
-    let item = menu.getElementsByAttribute("id", "node-menu-copyimagedatauri")[0];
-    ok(item, "The menu item was found in the contextual menu");
-    is(item.getAttribute("disabled"), "", "The menu item is enabled");
-  }).then(() => closeNodeMenu(inspector));
+function* assertCopyImageDataAvailable(inspector) {
+  let menu = yield openNodeMenu(inspector);
+
+  let item = menu.getElementsByAttribute("id", "node-menu-copyimagedatauri")[0];
+  ok(item, "The menu item was found in the contextual menu");
+  is(item.getAttribute("disabled"), "", "The menu item is enabled");
+
+  yield closeNodeMenu(inspector);
 }
 
-function openNodeMenu(inspector) {
-  let def = promise.defer();
-
-  inspector.nodemenu.addEventListener("popupshown", function onOpen() {
-    inspector.nodemenu.removeEventListener("popupshown", onOpen, false);
-    def.resolve(inspector.nodemenu);
-  }, false);
+function* openNodeMenu(inspector) {
+  let onShown = once(inspector.nodemenu, "popupshown", false);
   inspector.nodemenu.hidden = false;
   inspector.nodemenu.openPopup();
-
-  return def.promise;
+  yield onShown;
+  return inspector.nodemenu;
 }
 
-function closeNodeMenu(inspector) {
-  let def = promise.defer();
-
-  inspector.nodemenu.addEventListener("popuphidden", function onClose() {
-    inspector.nodemenu.removeEventListener("popuphidden", onClose, false);
-    def.resolve(inspector.nodemenu);
-  }, false);
+function* closeNodeMenu(inspector) {
+  let onHidden = once(inspector.nodemenu, "popuphidden", false);
   inspector.nodemenu.hidden = true;
   inspector.nodemenu.hidePopup();
-
-  return def.promise;
+  yield onHidden;
+  return inspector.nodemenu;
 }
 
 function triggerCopyImageUrlAndWaitForClipboard(expected, inspector) {
   let def = promise.defer();
 
   SimpleTest.waitForClipboard(expected, () => {
-    inspector.markup.getContainer(inspector.selection.nodeFront).copyImageDataUri();
+    inspector.markup.getContainer(inspector.selection.nodeFront)
+                    .copyImageDataUri();
   }, () => {
-    ok(true, "The clipboard contains the expected value " + expected.substring(0, 50) + "...");
+    ok(true, "The clipboard contains the expected value " +
+             expected.substring(0, 50) + "...");
     def.resolve();
   }, () => {
-    ok(false, "The clipboard doesn't contain the expected value " + expected.substring(0, 50) + "...");
+    ok(false, "The clipboard doesn't contain the expected value " +
+              expected.substring(0, 50) + "...");
     def.resolve();
   });
 
   return def.promise;
 }
new file mode 100644
--- /dev/null
+++ b/devtools/client/inspector/markup/test/doc_markup_image_and_canvas.html
@@ -0,0 +1,24 @@
+<!DOCTYPE html>
+<html class="html">
+  <head class="head">
+    <meta charset=utf-8 />
+    <title>Image and Canvas markup-view test</title>
+  </head>
+  <body>
+    <div></div>
+    <img src="" />
+    <canvas class="canvas" width="600" height="600"></canvas>
+    <script type="text/javascript">
+      "use strict";
+
+      let context = document.querySelector(".canvas").getContext("2d");
+      context.beginPath();
+      context.moveTo(300, 0);
+      context.lineTo(600, 600);
+      context.lineTo(0, 600);
+      context.closePath();
+      context.fillStyle = "#ffc821";
+      context.fill();
+    </script>
+  </body>
+</html>
--- a/devtools/client/shared/test/test-actor.js
+++ b/devtools/client/shared/test/test-actor.js
@@ -451,16 +451,35 @@ var TestActor = exports.TestActor = prot
       property: Arg(1, "string")
     },
     response: {
       value: RetVal("string")
     }
   }),
 
   /**
+   * Get an attribute on a DOM Node.
+   * @param {String} selector The node selector
+   * @param {String} attribute The attribute name
+   * @return {String} value The attribute value
+   */
+  getAttribute: protocol.method(function (selector, attribute) {
+    let node = this._querySelector(selector);
+    return node.getAttribute(attribute);
+  }, {
+    request: {
+      selector: Arg(0, "string"),
+      property: Arg(1, "string")
+    },
+    response: {
+      value: RetVal("string")
+    }
+  }),
+
+  /**
    * Set an attribute on a DOM Node.
    * @param {String} selector The node selector
    * @param {String} attribute The attribute name
    * @param {String} value The attribute value
    */
   setAttribute: protocol.method(function (selector, attribute, value) {
     let node = this._querySelector(selector);
     node.setAttribute(attribute, value);