| Index: third_party/WebKit/LayoutTests/animations/animated-css-property-usecounter-for-transitions.html | 
| diff --git a/third_party/WebKit/LayoutTests/animations/animated-css-property-usecounter-for-transitions.html b/third_party/WebKit/LayoutTests/animations/animated-css-property-usecounter-for-transitions.html | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..4018c3ad43ed6d7f3e06e5c6f7727c45276d79a9 | 
| --- /dev/null | 
| +++ b/third_party/WebKit/LayoutTests/animations/animated-css-property-usecounter-for-transitions.html | 
| @@ -0,0 +1,62 @@ | 
| +<!DOCTYPE html> | 
| +<script src="../resources/testharness.js"></script> | 
| +<script src="../resources/testharnessreport.js"></script> | 
| + | 
| +<style> | 
| +#target { | 
| +  width: 100px; | 
| +  height: 100px; | 
| +  transition: width 1s; | 
| +} | 
| +</style> | 
| + | 
| +<div id="target"></div> | 
| + | 
| +<script> | 
| +'use strict'; | 
| + | 
| +function waitForProgress() { | 
| +  var initialWidth = getComputedStyle(target).width; | 
| +  return new Promise(resolve => { | 
| +    function poll() { | 
| +      var width = getComputedStyle(target).width; | 
| +      if (width === initialWidth) { | 
| +        requestAnimationFrame(poll); | 
| +      } else { | 
| +        resolve(); | 
| +      } | 
| +    } | 
| +    requestAnimationFrame(poll); | 
| +  }); | 
| +} | 
| + | 
| +async_test(t => { | 
| +  assert_true( | 
| +      internals.isCSSPropertyUseCounted(document, "width"), | 
| +      'Usage of width in style causes it to be counted in normal CSS ' + | 
| +      'property UseCounter'); | 
| +  assert_true( | 
| +      internals.isCSSPropertyUseCounted(document, "height"), | 
| +      'Usage of height in style causes it to be counted in normal CSS ' + | 
| +      'property UseCounter'); | 
| + | 
| +  assert_false( | 
| +      internals.isAnimatedCSSPropertyUseCounted(document, "width"), | 
| +      'Initially width animation has not been UseCounted'); | 
| +  assert_false( | 
| +      internals.isAnimatedCSSPropertyUseCounted(document, "height"), | 
| +      'Initially height animation has not been UseCounted'); | 
| + | 
| +  target.offsetTop;  // force recalc | 
| +  target.style.width = '200px'; | 
| + | 
| +  waitForProgress().then(t.step_func_done(() => { | 
| +    assert_true( | 
| +        internals.isAnimatedCSSPropertyUseCounted(document, "width"), | 
| +        'After triggering the transition, width has been counted'); | 
| +    assert_false( | 
| +        internals.isAnimatedCSSPropertyUseCounted(document, "height"), | 
| +        'Height is not animated, so not counted'); | 
| +  })); | 
| +}, 'Using CSS transitions causes UseCounter to be incremented.'); | 
| +</script> | 
|  |