haikuwebkit/LayoutTests/css3/calc/transitions.html

83 lines
2.3 KiB
HTML
Raw Permalink Normal View History

[Web Animations] Turn Web Animations with CSS integration on https://bugs.webkit.org/show_bug.cgi?id=184819 <rdar://problem/39597337> Reviewed by Dean Jackson. LayoutTests/imported/mozilla: * css-animations/test_animation-cancel.html: * css-animations/test_animation-computed-timing.html: * css-animations/test_animation-currenttime.html: * css-animations/test_animation-finish.html: * css-animations/test_animation-finished.html: * css-animations/test_animation-id.html: * css-animations/test_animation-pausing.html: * css-animations/test_animation-playstate.html: * css-animations/test_animation-ready.html: * css-animations/test_animation-reverse.html: * css-animations/test_animation-starttime.html: * css-animations/test_animations-dynamic-changes.html: * css-animations/test_cssanimation-animationname.html: * css-animations/test_document-get-animations.html: * css-animations/test_effect-target.html: * css-animations/test_element-get-animations.html: * css-animations/test_event-dispatch.html: * css-animations/test_event-order.html: * css-animations/test_keyframeeffect-getkeyframes.html: * css-animations/test_pseudoElement-get-animations.html: * css-animations/test_setting-effect.html: * css-transitions/test_animation-cancel.html: * css-transitions/test_animation-computed-timing.html: * css-transitions/test_animation-currenttime.html: * css-transitions/test_animation-finished.html: * css-transitions/test_animation-pausing.html: * css-transitions/test_animation-ready.html: * css-transitions/test_animation-starttime.html: * css-transitions/test_csstransition-transitionproperty.html: * css-transitions/test_document-get-animations.html: * css-transitions/test_effect-target.html: * css-transitions/test_element-get-animations.html: * css-transitions/test_event-dispatch.html: * css-transitions/test_keyframeeffect-getkeyframes.html: * css-transitions/test_pseudoElement-get-animations.html: * css-transitions/test_setting-effect.html: LayoutTests/imported/w3c: * web-platform-tests/css-timing-1/frames-timing-functions-output.html: * web-platform-tests/css/css-logical/animation-003.tentative.html: * web-platform-tests/css/css-scoping/keyframes-001.html: * web-platform-tests/web-animations/animation-model/keyframe-effects/effect-value-context.html: * web-platform-tests/web-animations/interfaces/Animatable/animate.html: * web-platform-tests/web-animations/timing-model/animations/current-time.html: Source/WebCore: * page/RuntimeEnabledFeatures.h: Source/WebKit: * Shared/WebPreferences.yaml: Source/WebKitLegacy/mac: * WebView/WebPreferences.mm: (+[WebPreferences initialize]): Source/WebKitLegacy/win: * WebPreferences.cpp: (WebPreferences::initializeDefaultSettings): Tools: * DumpRenderTree/TestOptions.h: LayoutTests: * TestExpectations: * animations/3d/matrix-transform-type-animation.html: * animations/3d/replace-filling-transform.html: * animations/3d/transform-origin-vs-functions.html: * animations/3d/transform-perspective.html: * animations/additive-transform-animations.html: * animations/animation-border-overflow.html: * animations/animation-callback-timestamp.html: * animations/animation-controller-drt-api.html: * animations/animation-direction-alternate-reverse-expected.txt: * animations/animation-direction-alternate-reverse.html: * animations/animation-direction-reverse-fill-mode-hardware.html: * animations/animation-direction-reverse-hardware-opacity.html: * animations/animation-direction-reverse-hardware.html: * animations/animation-direction-reverse-non-hardware.html: * animations/animation-direction-reverse-timing-functions-hardware.html: * animations/animation-direction-reverse-timing-functions.html: * animations/animation-direction.html: * animations/animation-followed-by-transition.html: * animations/animation-hit-test-transform.html: * animations/animation-hit-test.html: * animations/animation-internals-api-expected.txt: Removed. * animations/animation-internals-api-multiple-keyframes-expected.txt: Removed. * animations/animation-internals-api-multiple-keyframes.html: Removed. * animations/animation-internals-api.html: Removed. * animations/animation-offscreen-to-onscreen.html: * animations/animation-playstate-paused-style-resolution.html: * animations/big-rotation-expected.txt: * animations/big-rotation.html: * animations/change-completed-animation-transform.html: * animations/change-keyframes.html: * animations/combo-transform-rotate+scale.html: * animations/cross-fade-background-image.html: * animations/cross-fade-border-image-source.html: * animations/cross-fade-list-style-image.html: * animations/cross-fade-webkit-mask-box-image.html: * animations/duplicate-keys-expected.html: * animations/duplicate-keys.html: * animations/duplicated-keyframes-name.html: * animations/fill-forwards-end-state.html: * animations/fill-mode-forwards-zero-duration-expected.txt: * animations/fill-mode-forwards-zero-duration.html: * animations/fill-mode-removed.html: * animations/font-variations/font-stretch.html: * animations/font-variations/font-style.html: * animations/font-variations/font-variation-settings-order.html: * animations/font-variations/font-variation-settings-unlike.html: * animations/font-variations/font-variation-settings.html: * animations/font-variations/font-weight.html: * animations/generic-from-to.html: * animations/import.html: * animations/keyframe-multiple-timing-functions-transform.html: * animations/keyframe-timing-functions-transform.html: * animations/keyframe-timing-functions.html: * animations/keyframe-timing-functions2.html: * animations/keyframes-comma-separated.html: * animations/keyframes-dynamic.html: * animations/keyframes-infinite-iterations.html: * animations/keyframes-invalid-keys.html: * animations/keyframes-out-of-order.html: * animations/keyframes.html: * animations/leak-document-with-css-animation.html: * animations/lineheight-animation.html: * animations/longhand-timing-function.html: * animations/matrix-anim.html: * animations/missing-from-to-transforms.html: * animations/missing-from-to.html: * animations/missing-keyframe-properties-repeating.html: * animations/missing-keyframe-properties-timing-function.html: * animations/missing-keyframe-properties.html: * animations/missing-values-first-keyframe.html: * animations/missing-values-last-keyframe.html: * animations/multiple-animations-timing-function.html: * animations/multiple-animations.html: * animations/multiple-keyframes.html: * animations/negative-delay.html: * animations/pause-crash.html: * animations/play-state-start-paused.html: * animations/resources/animation-leak-iframe.html: * animations/simultaneous-start-left.html: * animations/simultaneous-start-transform.html: * animations/spring-function.html: * animations/stacking-context-unchanged-while-running.html: * animations/stop-animation-on-suspend.html: * animations/suspend-resume-animation-events.html: * animations/timing-functions.html: * animations/transition-and-animation-1.html: * animations/transition-and-animation-2.html: * animations/transition-and-animation-3.html: * animations/trigger-container-scroll-boundaries.html: * animations/trigger-container-scroll-empty.html: * animations/trigger-container-scroll-simple.html: * animations/unanimated-style.html: * animations/unprefixed-keyframes.html: * animations/width-using-ems.html: * compositing/animation/animated-composited-inside-hidden.html: * compositing/animation/computed-style-during-delay.html: * compositing/animation/layer-for-filling-animation.html: * compositing/backing/backface-visibility-flip.html: * compositing/backing/transform-transition-from-outside-view.html: * compositing/contents-scale/animating.html: * compositing/layer-creation/animation-overlap-with-children.html: * compositing/layer-creation/mismatched-rotated-transform-animation-overlap.html: * compositing/layer-creation/mismatched-rotated-transform-transition-overlap.html: * compositing/layer-creation/mismatched-transform-transition-overlap.html: * compositing/layer-creation/multiple-keyframes-animation-overlap.html: * compositing/layer-creation/overlap-animation-clipping.html: * compositing/layer-creation/overlap-animation-container.html: * compositing/layer-creation/overlap-animation.html: * compositing/layer-creation/scale-rotation-animation-overlap.html: * compositing/layer-creation/scale-rotation-transition-overlap.html: * compositing/layer-creation/translate-animation-overlap.html: * compositing/layer-creation/translate-scale-animation-overlap.html: * compositing/layer-creation/translate-scale-transition-overlap.html: * compositing/layer-creation/translate-transition-overlap.html: * compositing/overflow/overflow-positioning.html: * compositing/reflections/animation-inside-reflection.html: * compositing/reflections/nested-reflection-animated.html: * compositing/reflections/nested-reflection-transition.html: * compositing/scrolling/touch-scroll-to-clip.html: * compositing/transitions/scale-transition-no-start.html: * compositing/transitions/singular-scale-transition.html: * compositing/visible-rect/animated-from-none.html: * compositing/visible-rect/animated.html: * css3/calc/transitions-dependent.html: * css3/calc/transitions.html: * css3/filters/backdrop/animation.html: * css3/filters/composited-during-animation.html: * css3/filters/filter-animation-from-none-hw.html: * css3/filters/filter-animation-from-none-multi-hw.html: * css3/filters/filter-animation-from-none-multi.html: * css3/filters/filter-animation-from-none.html: * css3/filters/filter-animation-hw.html: * css3/filters/filter-animation-multi-hw.html: * css3/filters/filter-animation-multi.html: * css3/filters/filter-animation.html: * css3/masking/clip-path-animation.html: * fast/animation/css-animation-resuming-when-visible-with-style-change.html: * fast/animation/css-animation-resuming-when-visible-with-style-change2.html: * fast/animation/css-animation-resuming-when-visible.html: * fast/animation/css-animation-throttling-lowPowerMode.html: * fast/animation/height-auto-transition-computed-value.html: * fast/css-generated-content/pseudo-animation.html: * fast/css-generated-content/pseudo-transition.html: * fast/filter-image/filter-image-animation.html: * fast/shapes/shape-outside-floats/shape-outside-animation.html: * fast/shapes/shape-outside-floats/shape-outside-shape-image-threshold-animation.html: * fast/shapes/shape-outside-floats/shape-outside-shape-margin-animation.html: * http/wpt/css/css-animations/start-animation-001.html: * imported/blink/transitions/transition-not-interpolable.html: * imported/blink/transitions/unprefixed-transform.html: * platform/ios/TestExpectations: * platform/win/TestExpectations: * transitions/remove-transition-style.html: * transitions/transition-drt-api-delay-expected.txt: Removed. * transitions/transition-drt-api-delay.html: Removed. * transitions/transition-drt-api-expected.txt: Removed. * transitions/transition-drt-api.html: Removed. * transitions/zero-duration-with-non-zero-delay-end.html: Canonical link: https://commits.webkit.org/204981@main git-svn-id: https://svn.webkit.org/repository/webkit/trunk@236541 268f45cc-cd09-0410-ab3c-d52691b4dbfc
2018-09-27 09:49:52 +00:00
<!DOCTYPE html>
<style>
.transitionTest {
background-color: green;
height: 100px;
-webkit-transition: all 1s linear;
-moz-transition: all 1s linear;
}
#startCalcEndCalc, #startCalcEndPx, #startCalcEndPercent {
CSS3 calc: unprefix implementation https://bugs.webkit.org/show_bug.cgi?id=91951 Reviewed by Ojan Vafai. Source/WebCore: Add support for the unprefixed 'calc()' function, while retaining support for the prefixed version. Test: css3/calc/simple-calcs-prefixed.html * css/CSSCalculationValue.cpp: (WebCore::buildCssText): (WebCore::CSSCalcValue::create): * css/CSSParser.cpp: (WebCore::CSSParser::isCalculation): (WebCore::CSSParser::detectFunctionTypeToken): LayoutTests: Changed all -webkit-calc() occurrences to calc(). Made a copy of the simplest test file so very basic tests for the prefixed version are retained. * css3/calc/background-position-parsing.html: * css3/calc/block-mask-overlay-image-outset.html: * css3/calc/border-radius.html: * css3/calc/border.html: * css3/calc/box-reflect.html: * css3/calc/calc-errors.html: * css3/calc/color-hsl.html: * css3/calc/color-rgb.html: * css3/calc/css3-radial-gradients.html: * css3/calc/cssom-expected.txt: * css3/calc/cssom.html: * css3/calc/font-monospace.html: * css3/calc/font-size-fractional.html: * css3/calc/font-size.html: * css3/calc/font.html: * css3/calc/getComputedStyle-margin-percentage.html: * css3/calc/gradient-color-stops.html: * css3/calc/img-size.html: * css3/calc/line-height.html: * css3/calc/margin.html: * css3/calc/negative-padding.html: * css3/calc/padding.html: * css3/calc/reflection-computed-style-expected.txt: * css3/calc/reflection-computed-style.html: * css3/calc/regression-62276.html: * css3/calc/simple-calcs-prefixed-expected.txt: Added. * css3/calc/simple-calcs-prefixed.html: Copied from LayoutTests/css3/calc/simple-calcs.html. * css3/calc/simple-calcs.html: * css3/calc/simple-composited-mask.html: * css3/calc/table-border-spacing.html: * css3/calc/table-calcs.html: * css3/calc/table-empty-cells.html: * css3/calc/transforms-scale.html: * css3/calc/transforms-translate.html: * css3/calc/transition-crash.html: * css3/calc/transition-crash2.html: * css3/calc/transition-crash3.html: * css3/calc/transition-crash4.html: * css3/calc/transitions-dependent.html: * css3/calc/transitions.html: * css3/calc/vertical-align-expected.html: * css3/calc/vertical-align.html: * css3/calc/zoom-with-em.html: Canonical link: https://commits.webkit.org/125653@main git-svn-id: https://svn.webkit.org/repository/webkit/trunk@140300 268f45cc-cd09-0410-ab3c-d52691b4dbfc
2013-01-21 07:05:16 +00:00
width: calc(10% + 50px);
width: -moz-calc(10% + 50px);
}
#startPxEndCalc {
width: 100px;
}
#startPercentEndCalc {
width: 20%;
}
#startCalcEndCalc.go, #startPxEndCalc.go, #startPercentEndCalc.go {
CSS3 calc: unprefix implementation https://bugs.webkit.org/show_bug.cgi?id=91951 Reviewed by Ojan Vafai. Source/WebCore: Add support for the unprefixed 'calc()' function, while retaining support for the prefixed version. Test: css3/calc/simple-calcs-prefixed.html * css/CSSCalculationValue.cpp: (WebCore::buildCssText): (WebCore::CSSCalcValue::create): * css/CSSParser.cpp: (WebCore::CSSParser::isCalculation): (WebCore::CSSParser::detectFunctionTypeToken): LayoutTests: Changed all -webkit-calc() occurrences to calc(). Made a copy of the simplest test file so very basic tests for the prefixed version are retained. * css3/calc/background-position-parsing.html: * css3/calc/block-mask-overlay-image-outset.html: * css3/calc/border-radius.html: * css3/calc/border.html: * css3/calc/box-reflect.html: * css3/calc/calc-errors.html: * css3/calc/color-hsl.html: * css3/calc/color-rgb.html: * css3/calc/css3-radial-gradients.html: * css3/calc/cssom-expected.txt: * css3/calc/cssom.html: * css3/calc/font-monospace.html: * css3/calc/font-size-fractional.html: * css3/calc/font-size.html: * css3/calc/font.html: * css3/calc/getComputedStyle-margin-percentage.html: * css3/calc/gradient-color-stops.html: * css3/calc/img-size.html: * css3/calc/line-height.html: * css3/calc/margin.html: * css3/calc/negative-padding.html: * css3/calc/padding.html: * css3/calc/reflection-computed-style-expected.txt: * css3/calc/reflection-computed-style.html: * css3/calc/regression-62276.html: * css3/calc/simple-calcs-prefixed-expected.txt: Added. * css3/calc/simple-calcs-prefixed.html: Copied from LayoutTests/css3/calc/simple-calcs.html. * css3/calc/simple-calcs.html: * css3/calc/simple-composited-mask.html: * css3/calc/table-border-spacing.html: * css3/calc/table-calcs.html: * css3/calc/table-empty-cells.html: * css3/calc/transforms-scale.html: * css3/calc/transforms-translate.html: * css3/calc/transition-crash.html: * css3/calc/transition-crash2.html: * css3/calc/transition-crash3.html: * css3/calc/transition-crash4.html: * css3/calc/transitions-dependent.html: * css3/calc/transitions.html: * css3/calc/vertical-align-expected.html: * css3/calc/vertical-align.html: * css3/calc/zoom-with-em.html: Canonical link: https://commits.webkit.org/125653@main git-svn-id: https://svn.webkit.org/repository/webkit/trunk@140300 268f45cc-cd09-0410-ab3c-d52691b4dbfc
2013-01-21 07:05:16 +00:00
width: calc(100% - 100px);
width: -moz-calc(100% - 100px);
}
#startCalcEndPx.go {
width: 400px;
}
#startCalcEndPercent.go {
width: 80%;
}
</style>
This tests that transitions containing calc() expressions transition correctly.
<div style="width:500px; border: 1px solid black;">
<div class="transitionTest" id="startCalcEndCalc"></div>
<div class="transitionTest" id="startPxEndCalc"></div>
<div class="transitionTest" id="startPercentEndCalc"></div>
<div class="transitionTest" id="startCalcEndPx"></div>
<div class="transitionTest" id="startCalcEndPercent"></div>
</div>
<div id="result"></div>
<script src="../../transitions/resources/transition-test-helpers.js"></script>
<script>
const tests = ["startCalcEndCalc", "startPxEndCalc", "startPercentEndCalc", "startCalcEndPx", "startCalcEndPercent"];
expectedValues = [];
for (var i = 0; i < tests.length; i++) {
expectedValues = expectedValues.concat([[0.25, tests[i], 'width', 175, 2]]);
expectedValues = expectedValues.concat([[0.5, tests[i], 'width', 250, 2]]);
expectedValues = expectedValues.concat([[0.75, tests[i], 'width', 325, 2]]);
expectedValues = expectedValues.concat([[1.0, tests[i], 'width', 400, 2]]);
}
function initialize(id)
{
var expectedStartWidth = 100;
var element = document.getElementById(id);
var width = element.offsetWidth;
if (width == expectedStartWidth)
element.innerHTML += 'PASS - "width" property for "' + id +'" element at 0.0s was: ' + width;
else
element.innerHTML += 'FAIL - "width" property for "' + id +'" element at 0.0s expected: ' + expectedStartWidth + ' but saw: ' + width;
element.className += " go";
}
function setupTest()
{
for (var i = 0; i < tests.length; i++)
initialize(tests[i]);
}
runTransitionTest(expectedValues, setupTest, true, false /* pixel test */);
</script>