gecko-dev/dom/smil/test/test_smilKeyTimes.xhtml
Robert O'Callahan 260b32ab87 Bug 946065. Part 3: Move content/smil to dom/smil. r=Ms2ger
--HG--
rename : content/smil/SMILBoolType.cpp => dom/smil/SMILBoolType.cpp
rename : content/smil/SMILBoolType.h => dom/smil/SMILBoolType.h
rename : content/smil/SMILEnumType.cpp => dom/smil/SMILEnumType.cpp
rename : content/smil/SMILEnumType.h => dom/smil/SMILEnumType.h
rename : content/smil/SMILIntegerType.cpp => dom/smil/SMILIntegerType.cpp
rename : content/smil/SMILIntegerType.h => dom/smil/SMILIntegerType.h
rename : content/smil/SMILStringType.cpp => dom/smil/SMILStringType.cpp
rename : content/smil/SMILStringType.h => dom/smil/SMILStringType.h
rename : content/smil/crashtests/483584-1.svg => dom/smil/crashtests/483584-1.svg
rename : content/smil/crashtests/483584-2.svg => dom/smil/crashtests/483584-2.svg
rename : content/smil/crashtests/523188-1.svg => dom/smil/crashtests/523188-1.svg
rename : content/smil/crashtests/525099-1.svg => dom/smil/crashtests/525099-1.svg
rename : content/smil/crashtests/526536-1.svg => dom/smil/crashtests/526536-1.svg
rename : content/smil/crashtests/526875-1.svg => dom/smil/crashtests/526875-1.svg
rename : content/smil/crashtests/526875-2.svg => dom/smil/crashtests/526875-2.svg
rename : content/smil/crashtests/529387-1-helper.svg => dom/smil/crashtests/529387-1-helper.svg
rename : content/smil/crashtests/529387-1.xhtml => dom/smil/crashtests/529387-1.xhtml
rename : content/smil/crashtests/531550-1.svg => dom/smil/crashtests/531550-1.svg
rename : content/smil/crashtests/537157-1.svg => dom/smil/crashtests/537157-1.svg
rename : content/smil/crashtests/541297-1.svg => dom/smil/crashtests/541297-1.svg
rename : content/smil/crashtests/547333-1.svg => dom/smil/crashtests/547333-1.svg
rename : content/smil/crashtests/548899-1.svg => dom/smil/crashtests/548899-1.svg
rename : content/smil/crashtests/551620-1.svg => dom/smil/crashtests/551620-1.svg
rename : content/smil/crashtests/554141-1.svg => dom/smil/crashtests/554141-1.svg
rename : content/smil/crashtests/554202-1.svg => dom/smil/crashtests/554202-1.svg
rename : content/smil/crashtests/554202-2.svg => dom/smil/crashtests/554202-2.svg
rename : content/smil/crashtests/555026-1.svg => dom/smil/crashtests/555026-1.svg
rename : content/smil/crashtests/556841-1.svg => dom/smil/crashtests/556841-1.svg
rename : content/smil/crashtests/572938-1.svg => dom/smil/crashtests/572938-1.svg
rename : content/smil/crashtests/572938-2.svg => dom/smil/crashtests/572938-2.svg
rename : content/smil/crashtests/572938-3.svg => dom/smil/crashtests/572938-3.svg
rename : content/smil/crashtests/572938-4.svg => dom/smil/crashtests/572938-4.svg
rename : content/smil/crashtests/588287-1.svg => dom/smil/crashtests/588287-1.svg
rename : content/smil/crashtests/588287-2.svg => dom/smil/crashtests/588287-2.svg
rename : content/smil/crashtests/590425-1.html => dom/smil/crashtests/590425-1.html
rename : content/smil/crashtests/592477-1.xhtml => dom/smil/crashtests/592477-1.xhtml
rename : content/smil/crashtests/594653-1.svg => dom/smil/crashtests/594653-1.svg
rename : content/smil/crashtests/596796-1.svg => dom/smil/crashtests/596796-1.svg
rename : content/smil/crashtests/605345-1.svg => dom/smil/crashtests/605345-1.svg
rename : content/smil/crashtests/606101-1.svg => dom/smil/crashtests/606101-1.svg
rename : content/smil/crashtests/608295-1.html => dom/smil/crashtests/608295-1.html
rename : content/smil/crashtests/608549-1.svg => dom/smil/crashtests/608549-1.svg
rename : content/smil/crashtests/611927-1.svg => dom/smil/crashtests/611927-1.svg
rename : content/smil/crashtests/615002-1.svg => dom/smil/crashtests/615002-1.svg
rename : content/smil/crashtests/615872-1.svg => dom/smil/crashtests/615872-1.svg
rename : content/smil/crashtests/641388-1.html => dom/smil/crashtests/641388-1.html
rename : content/smil/crashtests/641388-2.html => dom/smil/crashtests/641388-2.html
rename : content/smil/crashtests/650732-1.svg => dom/smil/crashtests/650732-1.svg
rename : content/smil/crashtests/665334-1.svg => dom/smil/crashtests/665334-1.svg
rename : content/smil/crashtests/669225-1.svg => dom/smil/crashtests/669225-1.svg
rename : content/smil/crashtests/669225-2.svg => dom/smil/crashtests/669225-2.svg
rename : content/smil/crashtests/670313-1.svg => dom/smil/crashtests/670313-1.svg
rename : content/smil/crashtests/678822-1.svg => dom/smil/crashtests/678822-1.svg
rename : content/smil/crashtests/678847-1.svg => dom/smil/crashtests/678847-1.svg
rename : content/smil/crashtests/678938-1.svg => dom/smil/crashtests/678938-1.svg
rename : content/smil/crashtests/690994-1.svg => dom/smil/crashtests/690994-1.svg
rename : content/smil/crashtests/691337-1.svg => dom/smil/crashtests/691337-1.svg
rename : content/smil/crashtests/691337-2.svg => dom/smil/crashtests/691337-2.svg
rename : content/smil/crashtests/697640-1.svg => dom/smil/crashtests/697640-1.svg
rename : content/smil/crashtests/699325-1.svg => dom/smil/crashtests/699325-1.svg
rename : content/smil/crashtests/709907-1.svg => dom/smil/crashtests/709907-1.svg
rename : content/smil/crashtests/720103-1.svg => dom/smil/crashtests/720103-1.svg
rename : content/smil/crashtests/crashtests.list => dom/smil/crashtests/crashtests.list
rename : content/smil/moz.build => dom/smil/moz.build
rename : content/smil/nsDOMTimeEvent.cpp => dom/smil/nsDOMTimeEvent.cpp
rename : content/smil/nsDOMTimeEvent.h => dom/smil/nsDOMTimeEvent.h
rename : content/smil/nsISMILAttr.h => dom/smil/nsISMILAttr.h
rename : content/smil/nsISMILType.h => dom/smil/nsISMILType.h
rename : content/smil/nsSMILAnimationController.cpp => dom/smil/nsSMILAnimationController.cpp
rename : content/smil/nsSMILAnimationController.h => dom/smil/nsSMILAnimationController.h
rename : content/smil/nsSMILAnimationFunction.cpp => dom/smil/nsSMILAnimationFunction.cpp
rename : content/smil/nsSMILAnimationFunction.h => dom/smil/nsSMILAnimationFunction.h
rename : content/smil/nsSMILCSSProperty.cpp => dom/smil/nsSMILCSSProperty.cpp
rename : content/smil/nsSMILCSSProperty.h => dom/smil/nsSMILCSSProperty.h
rename : content/smil/nsSMILCSSValueType.cpp => dom/smil/nsSMILCSSValueType.cpp
rename : content/smil/nsSMILCSSValueType.h => dom/smil/nsSMILCSSValueType.h
rename : content/smil/nsSMILCompositor.cpp => dom/smil/nsSMILCompositor.cpp
rename : content/smil/nsSMILCompositor.h => dom/smil/nsSMILCompositor.h
rename : content/smil/nsSMILCompositorTable.h => dom/smil/nsSMILCompositorTable.h
rename : content/smil/nsSMILFloatType.cpp => dom/smil/nsSMILFloatType.cpp
rename : content/smil/nsSMILFloatType.h => dom/smil/nsSMILFloatType.h
rename : content/smil/nsSMILInstanceTime.cpp => dom/smil/nsSMILInstanceTime.cpp
rename : content/smil/nsSMILInstanceTime.h => dom/smil/nsSMILInstanceTime.h
rename : content/smil/nsSMILInterval.cpp => dom/smil/nsSMILInterval.cpp
rename : content/smil/nsSMILInterval.h => dom/smil/nsSMILInterval.h
rename : content/smil/nsSMILKeySpline.cpp => dom/smil/nsSMILKeySpline.cpp
rename : content/smil/nsSMILKeySpline.h => dom/smil/nsSMILKeySpline.h
rename : content/smil/nsSMILMappedAttribute.cpp => dom/smil/nsSMILMappedAttribute.cpp
rename : content/smil/nsSMILMappedAttribute.h => dom/smil/nsSMILMappedAttribute.h
rename : content/smil/nsSMILMilestone.h => dom/smil/nsSMILMilestone.h
rename : content/smil/nsSMILNullType.cpp => dom/smil/nsSMILNullType.cpp
rename : content/smil/nsSMILNullType.h => dom/smil/nsSMILNullType.h
rename : content/smil/nsSMILParserUtils.cpp => dom/smil/nsSMILParserUtils.cpp
rename : content/smil/nsSMILParserUtils.h => dom/smil/nsSMILParserUtils.h
rename : content/smil/nsSMILRepeatCount.cpp => dom/smil/nsSMILRepeatCount.cpp
rename : content/smil/nsSMILRepeatCount.h => dom/smil/nsSMILRepeatCount.h
rename : content/smil/nsSMILSetAnimationFunction.cpp => dom/smil/nsSMILSetAnimationFunction.cpp
rename : content/smil/nsSMILSetAnimationFunction.h => dom/smil/nsSMILSetAnimationFunction.h
rename : content/smil/nsSMILTargetIdentifier.h => dom/smil/nsSMILTargetIdentifier.h
rename : content/smil/nsSMILTimeContainer.cpp => dom/smil/nsSMILTimeContainer.cpp
rename : content/smil/nsSMILTimeContainer.h => dom/smil/nsSMILTimeContainer.h
rename : content/smil/nsSMILTimeValue.cpp => dom/smil/nsSMILTimeValue.cpp
rename : content/smil/nsSMILTimeValue.h => dom/smil/nsSMILTimeValue.h
rename : content/smil/nsSMILTimeValueSpec.cpp => dom/smil/nsSMILTimeValueSpec.cpp
rename : content/smil/nsSMILTimeValueSpec.h => dom/smil/nsSMILTimeValueSpec.h
rename : content/smil/nsSMILTimeValueSpecParams.h => dom/smil/nsSMILTimeValueSpecParams.h
rename : content/smil/nsSMILTimedElement.cpp => dom/smil/nsSMILTimedElement.cpp
rename : content/smil/nsSMILTimedElement.h => dom/smil/nsSMILTimedElement.h
rename : content/smil/nsSMILTypes.h => dom/smil/nsSMILTypes.h
rename : content/smil/nsSMILValue.cpp => dom/smil/nsSMILValue.cpp
rename : content/smil/nsSMILValue.h => dom/smil/nsSMILValue.h
rename : content/smil/test/db_smilAnimateMotion.js => dom/smil/test/db_smilAnimateMotion.js
rename : content/smil/test/db_smilCSSFromBy.js => dom/smil/test/db_smilCSSFromBy.js
rename : content/smil/test/db_smilCSSFromTo.js => dom/smil/test/db_smilCSSFromTo.js
rename : content/smil/test/db_smilCSSPaced.js => dom/smil/test/db_smilCSSPaced.js
rename : content/smil/test/db_smilCSSPropertyList.js => dom/smil/test/db_smilCSSPropertyList.js
rename : content/smil/test/db_smilMappedAttrList.js => dom/smil/test/db_smilMappedAttrList.js
rename : content/smil/test/mochitest.ini => dom/smil/test/mochitest.ini
rename : content/smil/test/moz.build => dom/smil/test/moz.build
rename : content/smil/test/smilAnimateMotionValueLists.js => dom/smil/test/smilAnimateMotionValueLists.js
rename : content/smil/test/smilExtDoc_helper.svg => dom/smil/test/smilExtDoc_helper.svg
rename : content/smil/test/smilTestUtils.js => dom/smil/test/smilTestUtils.js
rename : content/smil/test/smilXHR_helper.svg => dom/smil/test/smilXHR_helper.svg
rename : content/smil/test/test_smilAccessKey.xhtml => dom/smil/test/test_smilAccessKey.xhtml
rename : content/smil/test/test_smilAnimateMotion.xhtml => dom/smil/test/test_smilAnimateMotion.xhtml
rename : content/smil/test/test_smilAnimateMotionInvalidValues.xhtml => dom/smil/test/test_smilAnimateMotionInvalidValues.xhtml
rename : content/smil/test/test_smilAnimateMotionOverrideRules.xhtml => dom/smil/test/test_smilAnimateMotionOverrideRules.xhtml
rename : content/smil/test/test_smilBackwardsSeeking.xhtml => dom/smil/test/test_smilBackwardsSeeking.xhtml
rename : content/smil/test/test_smilCSSFontStretchRelative.xhtml => dom/smil/test/test_smilCSSFontStretchRelative.xhtml
rename : content/smil/test/test_smilCSSFromBy.xhtml => dom/smil/test/test_smilCSSFromBy.xhtml
rename : content/smil/test/test_smilCSSFromTo.xhtml => dom/smil/test/test_smilCSSFromTo.xhtml
rename : content/smil/test/test_smilCSSInherit.xhtml => dom/smil/test/test_smilCSSInherit.xhtml
rename : content/smil/test/test_smilCSSInvalidValues.xhtml => dom/smil/test/test_smilCSSInvalidValues.xhtml
rename : content/smil/test/test_smilCSSPaced.xhtml => dom/smil/test/test_smilCSSPaced.xhtml
rename : content/smil/test/test_smilChangeAfterFrozen.xhtml => dom/smil/test/test_smilChangeAfterFrozen.xhtml
rename : content/smil/test/test_smilContainerBinding.xhtml => dom/smil/test/test_smilContainerBinding.xhtml
rename : content/smil/test/test_smilCrossContainer.xhtml => dom/smil/test/test_smilCrossContainer.xhtml
rename : content/smil/test/test_smilDynamicDelayedBeginElement.xhtml => dom/smil/test/test_smilDynamicDelayedBeginElement.xhtml
rename : content/smil/test/test_smilExtDoc.xhtml => dom/smil/test/test_smilExtDoc.xhtml
rename : content/smil/test/test_smilFillMode.xhtml => dom/smil/test/test_smilFillMode.xhtml
rename : content/smil/test/test_smilGetSimpleDuration.xhtml => dom/smil/test/test_smilGetSimpleDuration.xhtml
rename : content/smil/test/test_smilGetStartTime.xhtml => dom/smil/test/test_smilGetStartTime.xhtml
rename : content/smil/test/test_smilHyperlinking.xhtml => dom/smil/test/test_smilHyperlinking.xhtml
rename : content/smil/test/test_smilInvalidValues.html => dom/smil/test/test_smilInvalidValues.html
rename : content/smil/test/test_smilKeySplines.xhtml => dom/smil/test/test_smilKeySplines.xhtml
rename : content/smil/test/test_smilKeyTimes.xhtml => dom/smil/test/test_smilKeyTimes.xhtml
rename : content/smil/test/test_smilKeyTimesPacedMode.xhtml => dom/smil/test/test_smilKeyTimesPacedMode.xhtml
rename : content/smil/test/test_smilMappedAttrFromBy.xhtml => dom/smil/test/test_smilMappedAttrFromBy.xhtml
rename : content/smil/test/test_smilMappedAttrFromTo.xhtml => dom/smil/test/test_smilMappedAttrFromTo.xhtml
rename : content/smil/test/test_smilMappedAttrPaced.xhtml => dom/smil/test/test_smilMappedAttrPaced.xhtml
rename : content/smil/test/test_smilMinTiming.html => dom/smil/test/test_smilMinTiming.html
rename : content/smil/test/test_smilRepeatDuration.html => dom/smil/test/test_smilRepeatDuration.html
rename : content/smil/test/test_smilRepeatTiming.xhtml => dom/smil/test/test_smilRepeatTiming.xhtml
rename : content/smil/test/test_smilReset.xhtml => dom/smil/test/test_smilReset.xhtml
rename : content/smil/test/test_smilRestart.xhtml => dom/smil/test/test_smilRestart.xhtml
rename : content/smil/test/test_smilSetCurrentTime.xhtml => dom/smil/test/test_smilSetCurrentTime.xhtml
rename : content/smil/test/test_smilSync.xhtml => dom/smil/test/test_smilSync.xhtml
rename : content/smil/test/test_smilSyncTransform.xhtml => dom/smil/test/test_smilSyncTransform.xhtml
rename : content/smil/test/test_smilSyncbaseTarget.xhtml => dom/smil/test/test_smilSyncbaseTarget.xhtml
rename : content/smil/test/test_smilTextZoom.xhtml => dom/smil/test/test_smilTextZoom.xhtml
rename : content/smil/test/test_smilTimeEvents.xhtml => dom/smil/test/test_smilTimeEvents.xhtml
rename : content/smil/test/test_smilTiming.xhtml => dom/smil/test/test_smilTiming.xhtml
rename : content/smil/test/test_smilTimingZeroIntervals.xhtml => dom/smil/test/test_smilTimingZeroIntervals.xhtml
rename : content/smil/test/test_smilUpdatedInterval.xhtml => dom/smil/test/test_smilUpdatedInterval.xhtml
rename : content/smil/test/test_smilValues.xhtml => dom/smil/test/test_smilValues.xhtml
rename : content/smil/test/test_smilXHR.xhtml => dom/smil/test/test_smilXHR.xhtml
extra : rebase_source : 4038f574b020b79d3725efd91eeef457d9d6a0b0
2014-01-03 14:49:22 +13:00

392 lines
11 KiB
HTML

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Test for SMIL keyTimes</title>
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
</head>
<body>
<a target="_blank"
href="https://bugzilla.mozilla.org/show_bug.cgi?id=557885">Mozilla Bug
557885</a>
<p id="display"></p>
<div id="content" style="display: none">
<svg id="svg" xmlns="http://www.w3.org/2000/svg" width="120px" height="120px">
<circle cx="-100" cy="20" r="15" fill="blue" id="circle"/>
</svg>
</div>
<pre id="test">
<script class="testbody" type="text/javascript">
<![CDATA[
/** Test for SMIL keyTimes **/
var gSvg = document.getElementById("svg");
SimpleTest.waitForExplicitFinish();
function main()
{
gSvg.pauseAnimations();
var testCases = Array();
// Simple case
testCases.push({
'attr' : { 'values': '0; 50; 100',
'keyTimes': '0; .8; 1' },
'times': [ [ 4, 25 ],
[ 8, 50 ],
[ 9, 75 ],
[ 10, 100 ] ]
});
// Parsing tests
testCases.push(parseOk(' 0 ; .8;1 ')); // extra whitespace
testCases.push(parseNotOk(';0; .8; 1')); // leading semi-colon
testCases.push(parseNotOk('; .8; 1')); // leading semi-colon
testCases.push(parseOk('0; .8; 1;')); // trailing semi-colon
testCases.push(parseNotOk('')); // empty string
testCases.push(parseNotOk(' ')); // empty string
testCases.push(parseNotOk('0; .8')); // too few values
testCases.push(parseNotOk('0; .8; .9; 1')); // too many values
testCases.push(parseNotOk('0; 1; .8')); // non-increasing
testCases.push(parseNotOk('0; .8; .9')); // final value non-1 with
// calcMode=linear
testCases.push(parseOk('0; .8; .9', { 'calcMode': 'discrete' }));
testCases.push(parseNotOk('0.01; .8; 1')); // first value not 0
testCases.push(parseNotOk('0.01; .8; 1', { 'calcMode': 'discrete' }));
// first value not 0
testCases.push(parseNotOk('0; .8; 1.1')); // out of range
testCases.push(parseNotOk('-0.1; .8; 1')); // out of range
// 2 values
testCases.push({
'attr' : { 'values': '0; 50',
'keyTimes': '0; 1' },
'times': [ [ 6, 30 ] ]
});
// 1 value
testCases.push({
'attr' : { 'values': '50',
'keyTimes': ' 0' },
'times': [ [ 7, 50 ] ]
});
// 1 bad value
testCases.push({
'attr' : { 'values': '50',
'keyTimes': '0.1' },
'times': [ [ 0, -100 ] ]
});
// 1 value, calcMode=discrete
testCases.push({
'attr' : { 'values': '50',
'calcMode': 'discrete',
'keyTimes': ' 0' },
'times': [ [ 7, 50 ] ]
});
// 1 bad value, calcMode=discrete
testCases.push({
'attr' : { 'values': '50',
'calcMode': 'discrete',
'keyTimes': '0.1' },
'times': [ [ 0, -100 ] ]
});
// from-to
testCases.push({
'attr' : { 'from': '10',
'to': '20',
'keyTimes': '0.0; 1.0' },
'times': [ [ 3.5, 13.5 ] ]
});
// from-to calcMode=discrete
testCases.push({
'attr' : { 'from': '10',
'to': '20',
'calcMode': 'discrete',
'keyTimes': '0.0; 0.7' },
'times': [ [ 0, 10 ],
[ 6.9, 10 ],
[ 7.0, 20 ],
[ 10.0, 20 ],
[ 11.0, 20 ] ]
});
// from-to calcMode=discrete one keyTime only
testCases.push({
'attr' : { 'values': '20',
'calcMode': 'discrete',
'keyTimes': '0' },
'times': [ [ 0, 20 ],
[ 6.9, 20 ],
[ 7.0, 20 ],
[ 10.0, 20 ],
[ 11.0, 20 ] ]
});
// from-to calcMode=discrete one keyTime, mismatches no. values
testCases.push({
'attr' : { 'values': '10; 20',
'calcMode': 'discrete',
'keyTimes': '0' },
'times': [ [ 0, -100 ] ]
});
// to
testCases.push({
'attr' : { 'to': '100',
'keyTimes': '0.0; 1.0' },
'times': [ [ 0, -100 ],
[ 7, 40 ] ]
});
// to -- bad number of keyTimes (too many)
testCases.push({
'attr' : { 'to': '100',
'keyTimes': '0.0; 0.5; 1.0' },
'times': [ [ 2, -100 ] ]
});
// unfrozen to calcMode=discrete two keyTimes
testCases.push({
'attr' : { 'to': '100',
'calcMode': 'discrete',
'keyTimes': '0.0; 1.0',
'fill': 'remove' },
'times': [ [ 0, -100 ],
[ 7, -100 ],
[ 10, -100 ],
[ 12, -100 ]]
});
// frozen to calcMode=discrete two keyTimes
testCases.push({
'attr' : { 'to': '100',
'calcMode': 'discrete',
'keyTimes': '0.0; 1.0' },
'times': [ [ 0, -100 ],
[ 7, -100 ],
[ 10, 100 ],
[ 12, 100 ] ]
});
// to calcMode=discrete -- bad number of keyTimes (one, expecting two)
testCases.push({
'attr' : { 'to': '100',
'calcMode': 'discrete',
'keyTimes': '0' },
'times': [ [ 0, -100 ],
[ 7, -100 ] ]
});
// values calcMode=discrete
testCases.push({
'attr' : { 'values': '0; 10; 20; 30',
'calcMode': 'discrete',
'keyTimes': '0;.2;.4;.6' },
'times': [ [ 0, 0 ],
[ 1.9, 0 ],
[ 2, 10 ],
[ 3.9, 10 ],
[ 4.0, 20 ],
[ 5.9, 20 ],
[ 6.0, 30 ],
[ 9.9, 30 ],
[ 10.0, 30 ] ]
});
// The following two accumulate tests are from SMIL 3.0
// (Note that this behaviour differs from that defined for SVG Tiny 1.2 which
// specifically excludes the last value: "Note that in the case of discrete
// animation, the frozen value that is used is the value of the animation just
// before the end of the active duration.")
// accumulate=none
testCases.push({
'attr' : { 'values': '0; 10; 20',
'calcMode': 'discrete',
'keyTimes': '0;.5;1',
'fill': 'freeze',
'repeatCount': '2',
'accumulate': 'none' },
'times': [ [ 0, 0 ],
[ 5, 10 ],
[ 10, 0 ],
[ 15, 10 ],
[ 20, 20 ],
[ 25, 20 ] ]
});
// accumulate=sum
testCases.push({
'attr' : { 'values': '0; 10; 20',
'calcMode': 'discrete',
'keyTimes': '0;.5;1',
'fill': 'freeze',
'repeatCount': '2',
'accumulate': 'sum' },
'times': [ [ 0, 0 ],
[ 5, 10 ],
[ 10, 20 ],
[ 15, 30 ],
[ 20, 40 ],
[ 25, 40 ] ]
});
// If the interpolation mode is paced, the keyTimes attribute is ignored.
testCases.push({
'attr' : { 'values': '0; 10; 20',
'calcMode': 'paced',
'keyTimes': '0;.2;1' },
'times': [ [ 0, 0 ],
[ 2, 4 ],
[ 5, 10 ] ]
});
// SMIL 3 has:
// If the simple duration is indefinite and the interpolation mode is
// linear or spline, any keyTimes specification will be ignored.
// However, since keyTimes represent "a proportional offset into the simple
// duration of the animation element" surely discrete animation too cannot use
// keyTimes when the simple duration is indefinite. Hence SVGT 1.2 is surely
// more correct when it has:
// If the simple duration is indefinite, any 'keyTimes' specification will
// be ignored.
// (linear)
testCases.push({
'attr' : { 'values': '0; 10; 20',
'dur': 'indefinite',
'keyTimes': '0;.2;1' },
'times': [ [ 0, 0 ],
[ 5, 0 ] ]
});
// (spline)
testCases.push({
'attr' : { 'values': '0; 10; 20',
'dur': 'indefinite',
'calcMode': 'spline',
'keyTimes': '0;.2;1',
'keySplines': '0 0 1 1; 0 0 1 1' },
'times': [ [ 0, 0 ],
[ 5, 0 ] ]
});
// (discrete)
testCases.push({
'attr' : { 'values': '0; 10; 20',
'dur': 'indefinite',
'calcMode': 'discrete',
'keyTimes': '0;.2;1' },
'times': [ [ 0, 0 ],
[ 5, 0 ] ]
});
for (var i = 0; i < testCases.length; i++) {
gSvg.setCurrentTime(0);
var test = testCases[i];
// Create animation elements
var anim = createAnim(test.attr);
// Run samples
for (var j = 0; j < test.times.length; j++) {
var times = test.times[j];
gSvg.setCurrentTime(times[0]);
checkSample(anim, times[1], times[0], i);
}
anim.parentNode.removeChild(anim);
}
// fallback to discrete for non-additive animation
var attr = { 'values': 'butt; round; square',
'attributeName': 'stroke-linecap',
'calcMode': 'linear',
'keyTimes': '0;.2;1',
'fill': 'remove' };
var anim = createAnim(attr);
var samples = [ [ 0, 'butt' ],
[ 1.9, 'butt' ],
[ 2.0, 'round' ],
[ 9.9, 'round' ],
[ 10, 'butt' ] // fill=remove so we'll never set it to square
];
for (var i = 0; i < samples.length; i++) {
var sample = samples[i];
gSvg.setCurrentTime(sample[0]);
checkLineCapSample(anim, sample[1], sample[0],
"[non-interpolatable fallback]");
}
anim.parentNode.removeChild(anim);
SimpleTest.finish();
}
function parseOk(str, extra)
{
var attr = { 'values': '0; 50; 100',
'keyTimes': str };
if (typeof(extra) == "object") {
for (name in extra) {
attr[name] = extra[name];
}
}
return {
'attr' : attr,
'times': [ [ 0, 0 ] ]
};
}
function parseNotOk(str, extra)
{
var result = parseOk(str, extra);
result.times = [ [ 0, -100 ] ];
return result;
}
function createAnim(attr)
{
const svgns = "http://www.w3.org/2000/svg";
var anim = document.createElementNS(svgns, 'animate');
anim.setAttribute('attributeName','cx');
anim.setAttribute('dur','10s');
anim.setAttribute('begin','0s');
anim.setAttribute('fill','freeze');
for (name in attr) {
anim.setAttribute(name, attr[name]);
}
return document.getElementById('circle').appendChild(anim);
}
function checkSample(anim, expectedValue, sampleTime, caseNum)
{
var msg = "Test case " + caseNum +
" (keyTimes: '" + anim.getAttribute('keyTimes') + "'" +
" calcMode: " + anim.getAttribute('calcMode') + "), " +
"t=" + sampleTime +
": Unexpected sample value:";
is(anim.targetElement.cx.animVal.value, expectedValue, msg);
}
function checkLineCapSample(anim, expectedValue, sampleTime, caseDescr)
{
var msg = "Test case " + caseDescr +
" (keyTimes: '" + anim.getAttribute('keyTimes') + "'" +
" calcMode: " + anim.getAttribute('calcMode') + "), " +
"t=" + sampleTime +
": Unexpected sample value:";
var actualValue =
window.getComputedStyle(anim.targetElement, null).
getPropertyValue('stroke-linecap');
is(actualValue, expectedValue, msg);
}
window.addEventListener("load", main, false);
]]>
</script>
</pre>
</body>
</html>