/* Any copyright is dedicated to the public domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

// Test the getScreenshot property for mozbrowser
"use strict";

SimpleTest.waitForExplicitFinish();
browserElementTestHelpers.setEnabledPref(true);

function runTest() {
  var dppxPref = 'layout.css.devPixelsPerPx';
  var cssPixelWidth = 600;
  var cssPixelHeight = 400;

  var iframe1 = document.createElement('iframe');
  iframe1.setAttribute('width', cssPixelWidth);
  iframe1.setAttribute('height', cssPixelHeight);
  iframe1.setAttribute('mozbrowser', 'true');

  iframe1.src = 'data:text/html,<html><body>hello</body></html>';
  document.body.appendChild(iframe1);

  var images = [];

  function screenshotTaken(image) {
    images.push(image);
    if (images.length === 1) {
      ok(true, 'Got initial non blank screenshot');

      if (image.width !== cssPixelWidth || image.height !== cssPixelHeight) {
        ok(false, 'The pixel width of the image received is not correct');
        SimpleTest.finish();
        return;
      }
      ok(true, 'The pixel width of the image received is correct');

      SpecialPowers.pushPrefEnv(
        {'set': [['layout.css.devPixelsPerPx', 2]]}, takeScreenshot);
    }
    else if (images.length === 2) {
      ok(true, 'Got updated screenshot after source page changed');

      if (image.width !== cssPixelWidth * 2 ||
          image.height !== cssPixelHeight * 2) {
        ok(false, 'The pixel width of the 2dppx image received is not correct');
        SimpleTest.finish();
        return;
      }
      ok(true, 'The pixel width of the 2dppx image received is correct');
      SimpleTest.finish();
    }
  }

  function takeScreenshot() {
    function gotImage(e) {
      // |this| is the Image.

      URL.revokeObjectURL(this.src);

      if (e.type === 'error' || !this.width || !this.height) {
        tryAgain();

        return;
      }

      screenshotTaken(this);
    }

    function tryAgain() {
      if (--attempts === 0) {
        ok(false, 'Timed out waiting for correct screenshot');
        SimpleTest.finish();
      } else {
        setTimeout(function() {
          iframe1.getScreenshot(cssPixelWidth, cssPixelHeight).onsuccess =
            getScreenshotImageData;
        }, 200);
      }
    }

    function getScreenshotImageData(e) {
      var blob = e.target.result;
      if (blob.size === 0) {
        tryAgain();

        return;
      }

      var img = new Image();
      img.src = URL.createObjectURL(blob);
      img.onload = img.onerror = gotImage;
    }

    var attempts = 10;
    iframe1.getScreenshot(cssPixelWidth, cssPixelHeight).onsuccess =
      getScreenshotImageData;
  }

  function iframeLoadedHandler() {
    SpecialPowers.pushPrefEnv(
      {'set': [['layout.css.devPixelsPerPx', 1]]}, takeScreenshot);
  }

  iframe1.addEventListener('mozbrowserloadend', iframeLoadedHandler);
}

addEventListener('testready', runTest);