chromium/third_party/blink/web_tests/external/wpt/uievents/order-of-events/mouse-events/wheel-basic.html

<!doctype html>
<head>
  <meta charset=utf-8>
  <title>WheelEvent - basic wheel event</title>
  <style>
    .testarea{ margin: auto; width: 800px; height: 250px; border: 1px solid grey; position: relative; }

    #wheelbox, #scrollbox { background-color: red; border: 1px solid black; margin: 0; padding: 0; }
    #wheelbox.green, #scrollbox.green { background-color: green; }
    #wheelbox { position: absolute; left: 15%; top: 15%; width: 50%; height: 50% }
    #scrollbox { position: absolute; right: 15%; bottom: 15%; width: 50%; height: 50% }
  </style>
  <script src="/resources/testharness.js"></script>
  <script src="/resources/testharnessreport.js"></script>
  <script src="/resources/testdriver.js"></script>
  <script src="/resources/testdriver-actions.js"></script>
  <script src="/resources/testdriver-vendor.js"></script>
  <script>
    setup({explicit_timeout: true});
  </script>
  <script src="/uievents/resources/eventrecorder.js"></script>
</head>

<body>
  <p><strong>Description</strong>: Verifies that wheel events are captured and sent</p>
  <p><strong>Instructions</strong>: </p>
  <ol>
    <li>Place your mouse pointer over the top box</li>
    <li>Scroll the mouse wheel to change the box color</li>
    <li>Move the mouse pointer to the second box</li>
    <li>Scroll the mouse wheel again to change this box's color</li>
  </ol>
  <p><strong>Test Passes</strong> if the box turns green and the word 'PASS' appears below</p>

  <section class="testarea">
    <div id="scrollbox"></div>
    <div id="wheelbox"></div>
  </section>

  <script>
    var wheelbox = document.getElementById("wheelbox");
    var scrollbox = document.getElementById("scrollbox");
    var test_wheel = async_test("wheel event test");
    var actions_promise;

    EventRecorder.configure({
      mergeEventTypes: ['wheel'],
      objectMap: {
        "div#wheelbox": wheelbox,
        "div#scrollbox": scrollbox
      }
    });

    wheelbox.addRecordedEventListener('wheel', function (e) {
      e.stopPropagation();
      this.className = "green";
    });

    scrollbox.addRecordedEventListener('wheel', function (e) {
      e.stopPropagation();
      this.className = "green";
      endTest();
      // Make sure the test finishes after all the input actions are completed.
      actions_promise.then( () => {
        test_wheel.done();
      });
    });

    function endTest() {
      EventRecorder.stop();
      var results = EventRecorder.getRecords();
      test_wheel.step(function () {
        // Check results:
        assert_equals(results.length, 2, "Two mousemove events");
        assert_equals(results[0].event.type, 'wheel', "First event is a wheel event");
        assert_equals(results[1].event.type, 'wheel', "Second event is a wheel event");
        assert_equals(results[0].event.target, 'div#wheelbox', "First event targetted wheelbox");
        assert_equals(results[1].event.target, 'div#scrollbox', "Second event targetted scrollbox");
      });
    }

    EventRecorder.start();

    // Inject wheel inputs.
    actions_promise = new test_driver.Actions()
        .scroll(0, 0, 0, 10, {origin: wheelbox})
        .scroll(160, 50, 0, 20, {origin: scrollbox})
        .send();
  </script>
</body>
</html>