chromium/third_party/blink/web_tests/animations/usecounters/animated-css-property-usecounter-for-transitions.html

<!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>