summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/html/semantics/embedded-content/resources/common.js
blob: 06f18b3e0498549df1811c6a8008857e65b4117c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
// Helper to access the element, its associated loading promise, and also to
// resolve the promise.
class ElementLoadPromise {
  constructor(element_id) {
    this.element_id = element_id;
    this.promise = new Promise((resolve, reject) => {
      this.resolve = resolve
      this.reject = reject
    });
  }
  element() {
    return document.getElementById(this.element_id);
  }
}

// Returns if the image is complete and the lazily loaded image matches the expected image.
function is_image_fully_loaded(image, expected_image) {
  if (!image.complete || !expected_image.complete) {
    return false;
  }

  if (image.width != expected_image.width ||
      image.height != expected_image.height) {
    return false;
  }

  let canvas = document.createElement('canvas');
  canvas.width = image.width;
  canvas.height = image.height;
  let canvasContext = canvas.getContext("2d");
  canvasContext.save();
  canvasContext.drawImage(image, 0, 0);
  let data = canvasContext.getImageData(0, 0, canvas.width, canvas.height).data;

  canvasContext.restore();
  canvasContext.drawImage(expected_image, 0, 0);
  let expected_data = canvasContext.getImageData(0, 0, canvas.width, canvas.height).data;

  for (var i = 0; i < data.length; i++) {
    if (data[i] != expected_data[i]) {
      return false;
    }
  }
  return true;
}