<!DOCTYPE html>
<script src="../../resources/testharness.js"></script>
<script src="../../resources/testharnessreport.js"></script>
<svg width="500px" height="500px" viewBox="0 0 500 500">
<rect width="1" height="1"/>
<marker markerWidth="1" markerHeight="1"/>
</svg>
<script>
var viewportWidth = 500;
var EPSILON = Math.pow(2, -8);
var cssPixelsPerInch = 96;
var cssPixelsPerCentimeter = cssPixelsPerInch / 2.54; //2.54 cm/in
var cssPixelsPerMillimeter = cssPixelsPerCentimeter / 10;
var cssPixelsPerPoint = cssPixelsPerInch / 72;
var cssPixelsPerPica = cssPixelsPerInch / 6;
function viewportWidthPercent() {
return viewportWidth / 100;
}
function assert_calc_expression_on_width_attr(expression, expected) {
var rect = document.querySelector('rect');
var rectWidth;
// Test calc with setAttribute
rect.setAttribute('width', expression);
rectWidth = rect.getBoundingClientRect().width;
assert_approx_equals(rectWidth, expected, EPSILON);
assert_approx_equals(rect.width.baseVal.value, expected, EPSILON);
assert_equals(rect.width.baseVal.unitType, SVGLength.SVG_LENGTHTYPE_UNKNOWN);
assert_equals(rect.width.baseVal.valueInSpecifiedUnits, 0);
// Test valueInSpecifiedUnits setter after 'calc' value attribute
rect.width.baseVal.valueInSpecifiedUnits = 100;
assert_equals(rect.width.baseVal.unitType, SVGLength.SVG_LENGTHTYPE_NUMBER);
assert_equals(rect.width.baseVal.valueInSpecifiedUnits, 100);
// Test value setter after 'calc' value attribute
rect.setAttribute('width', expression); // reset to calc value
rect.width.baseVal.value = 10;
assert_equals(rect.width.baseVal.unitType, SVGLength.SVG_LENGTHTYPE_NUMBER);
assert_equals(rect.width.baseVal.valueInSpecifiedUnits, 10);
// Test calc with "valueAsString"
rect.setAttribute('width', '20px'); // reset to normal value
rect.width.baseVal.valueAsString = expression;
assert_approx_equals(rect.width.baseVal.value, expected, EPSILON);
}
function assert_calc_expression_on_markerWidth_attr(expression, expected) {
var marker = document.querySelector('marker');
// Test calc with setAttribute
marker.setAttribute('markerWidth', expression);
assert_approx_equals(marker.markerWidth.baseVal.value, expected, EPSILON);
assert_equals(marker.markerWidth.baseVal.unitType, SVGLength.SVG_LENGTHTYPE_UNKNOWN);
assert_equals(marker.markerWidth.baseVal.valueInSpecifiedUnits, 0);
// Test valueInSpecifiedUnits setter after 'calc' value attribute
marker.markerWidth.baseVal.valueInSpecifiedUnits = 100;
assert_equals(marker.markerWidth.baseVal.unitType, SVGLength.SVG_LENGTHTYPE_NUMBER);
assert_equals(marker.markerWidth.baseVal.valueInSpecifiedUnits, 100);
// Test value setter after 'calc' value attribute
marker.setAttribute('markerWidth', expression); // reset to calc value
marker.markerWidth.baseVal.value = 10;
assert_equals(marker.markerWidth.baseVal.unitType, SVGLength.SVG_LENGTHTYPE_NUMBER);
assert_equals(marker.markerWidth.baseVal.valueInSpecifiedUnits, 10);
// Test calc with "valueAsString"
marker.setAttribute('markerWidth', '20px'); // reset to normal value
marker.markerWidth.baseVal.valueAsString = expression;
assert_approx_equals(marker.markerWidth.baseVal.value, expected, EPSILON);
}
function assert_calc_expression(expression, expected) {
assert_calc_expression_on_width_attr(expression, expected); // presentation attr
assert_calc_expression_on_markerWidth_attr(expression, expected); // non presentation attr
}
test(function() {
assert_calc_expression("calc(20%)", (20 * viewportWidthPercent()));
assert_calc_expression("calc(10mm + 10in)", (10 * cssPixelsPerMillimeter) + (10 * cssPixelsPerInch));
assert_calc_expression("calc(10mm + 10mm)", (20 * cssPixelsPerMillimeter));
assert_calc_expression("calc(20mm)", (20 * cssPixelsPerMillimeter));
assert_calc_expression("calc(10 + 10)", 20);
assert_calc_expression("calc(10mm + 10px)", (10 * cssPixelsPerMillimeter) + 10);
assert_calc_expression("calc(10% + 10px)", (10 * viewportWidthPercent()) + 10);
assert_calc_expression("calc(1cm + 2in + 1cm + 2px)", (2 * cssPixelsPerInch) + (2 * cssPixelsPerCentimeter) + 2);
assert_calc_expression("calc(1cm + 2px + 1cm + 2in)", (2 * cssPixelsPerInch) + (2 * cssPixelsPerCentimeter) + 2);
assert_calc_expression("calc(10% + 10px + 2% + 10pc)", (12 * viewportWidthPercent()) + 10 + (10 * cssPixelsPerPica));
}, "Tests calc() on presentation and non-presentation attr in svgLength");
</script>