| <!DOCTYPE HTML> |
| <title>SVGMatrix interface</title> |
| <script src="../../resources/testharness.js"></script> |
| <script src="../../resources/testharnessreport.js"></script> |
| <script> |
| var svgElement = document.createElementNS("http://www.w3.org/2000/svg", "svg"); |
| |
| function assert_matrix_component_numeric(matrix, component) { |
| let original = matrix[component]; |
| assert_throws_js(TypeError, function() { matrix[component] = matrix; }); |
| assert_equals(matrix[component], original); |
| matrix[component] = 0; |
| assert_equals(matrix[component], 0); |
| assert_throws_js(TypeError, function() { matrix[component] = svgElement; }); |
| assert_equals(matrix[component], 0); |
| matrix[component] = 0; |
| assert_equals(matrix[component], 0); |
| assert_throws_js(TypeError, function() { matrix[component] = 'aString'; }); |
| assert_equals(matrix[component], 0); |
| } |
| |
| test(function() { |
| // This test checks the SVGMatrix API. |
| var matrix = svgElement.createSVGMatrix(); |
| |
| // Check initial matrix values. |
| assert_equals(matrix.a, 1); |
| assert_equals(matrix.b, 0); |
| assert_equals(matrix.c, 0); |
| assert_equals(matrix.d, 1); |
| assert_equals(matrix.e, 0); |
| assert_equals(matrix.f, 0); |
| |
| // Check assigning matrices. |
| matrix.a = 2; |
| assert_equals(matrix.a, 2); |
| matrix.f = 200; |
| assert_equals(matrix.f, 200); |
| |
| // Check assigning invalid matrices. |
| assert_matrix_component_numeric(matrix, 'a'); |
| // Reset to previous value. |
| matrix.a = 2; |
| assert_equals(matrix.a, 2); |
| |
| assert_matrix_component_numeric(matrix, 'b'); |
| // Reset to previous value. |
| matrix.b = 0; |
| assert_equals(matrix.b, 0); |
| |
| assert_matrix_component_numeric(matrix, 'c'); |
| // Reset to previous value. |
| matrix.c = 0; |
| assert_equals(matrix.c, 0); |
| |
| assert_matrix_component_numeric(matrix, 'd'); |
| // Reset to previous value. |
| matrix.d = 1; |
| assert_equals(matrix.d, 1); |
| |
| assert_matrix_component_numeric(matrix, 'e'); |
| // Reset to previous value. |
| matrix.e = 0; |
| assert_equals(matrix.e, 0); |
| |
| assert_matrix_component_numeric(matrix, 'f'); |
| // Reset to previous value. |
| matrix.f = 200; |
| assert_equals(matrix.f, 200); |
| |
| // Check that the matrix is still containing the correct values. |
| assert_equals(matrix.a, 2); |
| assert_equals(matrix.b, 0); |
| assert_equals(matrix.c, 0); |
| assert_equals(matrix.d, 1); |
| assert_equals(matrix.e, 0); |
| assert_equals(matrix.f, 200); |
| |
| // Check assigning null works as expected. |
| matrix.f = null; |
| assert_equals(matrix.a, 2); |
| assert_equals(matrix.b, 0); |
| assert_equals(matrix.c, 0); |
| assert_equals(matrix.d, 1); |
| assert_equals(matrix.e, 0); |
| assert_equals(matrix.f, 0); |
| |
| // Check calling 'multiply' with invalid arguments. |
| assert_throws_js(TypeError, function() { matrix.multiply(); }); |
| assert_throws_js(TypeError, function() { matrix.multiply(true); }); |
| assert_throws_js(TypeError, function() { matrix.multiply(2); }); |
| assert_throws_js(TypeError, function() { matrix.multiply('aString'); }); |
| assert_throws_js(TypeError, function() { matrix.multiply(svgElement); }); |
| |
| // Check calling 'translate' with invalid arguments. |
| assert_throws_js(TypeError, function() { matrix.translate(); }); |
| assert_throws_js(TypeError, function() { matrix.translate(true); }); |
| assert_throws_js(TypeError, function() { matrix.translate(2); }); |
| assert_throws_js(TypeError, function() { matrix.translate('aString'); }); |
| assert_throws_js(TypeError, function() { matrix.translate('aString', 'aString'); }); |
| assert_throws_js(TypeError, function() { matrix.translate(svgElement); }); |
| assert_throws_js(TypeError, function() { matrix.translate(svgElement, svgElement); }); |
| assert_throws_js(TypeError, function() { matrix.translate(2, 'aString'); }); |
| assert_throws_js(TypeError, function() { matrix.translate(2, svgElement); }); |
| assert_throws_js(TypeError, function() { matrix.translate('aString', 2); }); |
| assert_throws_js(TypeError, function() { matrix.translate(svgElement, 2); }); |
| |
| // Check calling 'scale' with invalid arguments. |
| assert_throws_js(TypeError, function() { matrix.scale(); }); |
| assert_throws_js(TypeError, function() { matrix.scale('aString'); }); |
| assert_throws_js(TypeError, function() { matrix.scale(svgElement); }); |
| |
| |
| // Check calling 'scaleNonUniform' with invalid arguments. |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform(); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform(true); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform(2); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform('aString'); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform(svgElement); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform('aString', 'aString'); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform(svgElement, svgElement); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform(2, 'aString'); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform(2, svgElement); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform('aString', 2); }); |
| assert_throws_js(TypeError, function() { matrix.scaleNonUniform(svgElement, 2); }); |
| |
| // Check calling 'rotate' with invalid arguments. |
| assert_throws_js(TypeError, function() { matrix.rotate(); }); |
| assert_throws_js(TypeError, function() { matrix.rotate('aString'); }); |
| assert_throws_js(TypeError, function() { matrix.rotate(svgElement); }); |
| |
| // Check calling 'rotateFromVector' with invalid arguments. |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector(); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector(true); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector(2); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector('aString'); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector(svgElement); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector('aString', 'aString'); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector(svgElement, svgElement); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector(2, 'aString'); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector(2, svgElement); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector('aString', 2); }); |
| assert_throws_js(TypeError, function() { matrix.rotateFromVector(svgElement, 2); }); |
| |
| // Check calling 'skewX' with invalid arguments. |
| assert_throws_js(TypeError, function() { matrix.skewX(); }); |
| assert_throws_js(TypeError, function() { matrix.skewX('aString'); }); |
| assert_throws_js(TypeError, function() { matrix.skewX(svgElement); }); |
| |
| // Check calling 'skewY' with invalid arguments; |
| assert_throws_js(TypeError, function() { matrix.skewY(); }); |
| assert_throws_js(TypeError, function() { matrix.skewY('aString'); }); |
| assert_throws_js(TypeError, function() { matrix.skewY(svgElement); }); |
| }); |
| </script> |