summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/html/canvas/element/pixel-manipulation/2d.imageData.object.ctor.basics.html
blob: f7811e7441c99ff6acc40d7ee11ae36f1a65fdc7 (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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<!DOCTYPE html>
<!-- DO NOT EDIT! This test has been generated by /html/canvas/tools/gentest.py. -->
<title>Canvas test: 2d.imageData.object.ctor.basics</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/html/canvas/resources/canvas-tests.js"></script>
<link rel="stylesheet" href="/html/canvas/resources/canvas-tests.css">
<body class="show_output">

<h1>2d.imageData.object.ctor.basics</h1>
<p class="desc">Testing different type of ImageData constructor</p>


<p class="output">Actual output:</p>
<canvas id="c" class="output" width="100" height="50"><p class="fallback">FAIL (fallback content)</p></canvas>

<ul id="d"></ul>
<script>
var t = async_test("Testing different type of ImageData constructor");
_addTest(function(canvas, ctx) {

  function setRGBA(imageData, i, rgba)
  {
      var s = i * 4;
      imageData[s] = rgba[0];
      imageData[s + 1] = rgba[1];
      imageData[s + 2] = rgba[2];
      imageData[s + 3] = rgba[3];
  }

  function getRGBA(imageData, i)
  {
      var result = [];
      var s = i * 4;
      for (var j = 0; j < 4; j++) {
          result[j] = imageData[s + j];
      }
      return result;
  }

  function assertArrayEquals(actual, expected)
  {
      _assertSame(typeof actual, "object", "typeof actual", "\"object\"");
      _assertDifferent(actual, null, "actual", "null");
      _assertSame("length" in actual, true, "\"length\" in actual", "true");
      _assertSame(actual.length, expected.length, "actual.length", "expected.length");
      for (var i = 0; i < actual.length; i++) {
          _assertSame(actual.hasOwnProperty(i), expected.hasOwnProperty(i), "actual.hasOwnProperty(i)", "expected.hasOwnProperty(i)");
          _assertSame(actual[i], expected[i], "actual[\""+(i)+"\"]", "expected[\""+(i)+"\"]");
      }
  }

  _assertDifferent(ImageData, undefined, "ImageData", "undefined");
  imageData = new ImageData(100, 50);

  _assertDifferent(imageData, null, "imageData", "null");
  _assertDifferent(imageData.data, null, "imageData.data", "null");
  _assertSame(imageData.width, 100, "imageData.width", "100");
  _assertSame(imageData.height, 50, "imageData.height", "50");
  assertArrayEquals(getRGBA(imageData.data, 4), [0, 0, 0, 0]);

  var testColor = [0, 255, 255, 128];
  setRGBA(imageData.data, 4, testColor);
  assertArrayEquals(getRGBA(imageData.data, 4), testColor);

  assert_throws_js(TypeError, function() { ImageData(1, 1); });
  assert_throws_js(TypeError, function() { new ImageData(10); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(0, 10); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(10, 0); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData('width', 'height'); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(1 << 31, 1 << 31); });
  assert_throws_js(TypeError, function() { new ImageData(new Uint8ClampedArray(0)); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(new Uint8Array(100), 25); });
  assert_throws_dom("INVALID_STATE_ERR", function() { new ImageData(new Uint8ClampedArray(27), 2); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(new Uint8ClampedArray(28), 7, 0); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(new Uint8ClampedArray(104), 14); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(new Uint8ClampedArray([12, 34, 168, 65328]), 1, 151); });
  assert_throws_js(TypeError, function() { new ImageData(self, 4, 4); });
  assert_throws_js(TypeError, function() { new ImageData(null, 4, 4); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(imageData.data, 0); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(imageData.data, 13); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(imageData.data, 1 << 31); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(imageData.data, 'biggish'); });
  assert_throws_dom("INDEX_SIZE_ERR", function() { new ImageData(imageData.data, 1 << 24, 1 << 31); });
  _assertSame(new ImageData(new Uint8ClampedArray(28), 7).height, 1, "new ImageData(new Uint8ClampedArray(28), 7).height", "1");

  imageDataFromData = new ImageData(imageData.data, 100);
  _assertSame(imageDataFromData.width, 100, "imageDataFromData.width", "100");
  _assertSame(imageDataFromData.height, 50, "imageDataFromData.height", "50");
  _assertSame(imageDataFromData.data, imageData.data, "imageDataFromData.data", "imageData.data");
  assertArrayEquals(getRGBA(imageDataFromData.data, 10), getRGBA(imageData.data, 10));
  setRGBA(imageData.data, 10, testColor);
  assertArrayEquals(getRGBA(imageDataFromData.data, 10), getRGBA(imageData.data, 10));

  var data = new Uint8ClampedArray(400);
  data[22] = 129;
  imageDataFromData = new ImageData(data, 20, 5);
  _assertSame(imageDataFromData.width, 20, "imageDataFromData.width", "20");
  _assertSame(imageDataFromData.height, 5, "imageDataFromData.height", "5");
  _assertSame(imageDataFromData.data, data, "imageDataFromData.data", "data");
  assertArrayEquals(getRGBA(imageDataFromData.data, 2), getRGBA(data, 2));
  setRGBA(imageDataFromData.data, 2, testColor);
  assertArrayEquals(getRGBA(imageDataFromData.data, 2), getRGBA(data, 2));

  if (window.SharedArrayBuffer) {
      assert_throws_js(TypeError, function() { new ImageData(new Uint16Array(new SharedArrayBuffer(32)), 4, 2); });
  }

});
</script>