mirror of
https://github.com/google/blockly.git
synced 2026-01-05 08:00:09 +01:00
* chore(deps): Bump chai from 4.3.10 to 5.1.1 Bumps [chai](https://github.com/chaijs/chai) from 4.3.10 to 5.1.1. - [Release notes](https://github.com/chaijs/chai/releases) - [Changelog](https://github.com/chaijs/chai/blob/main/History.md) - [Commits](https://github.com/chaijs/chai/compare/v4.3.10...v5.1.1) --- updated-dependencies: - dependency-name: chai dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] <support@github.com> * fix(tests): Migrate all usage of chai to ESM (#8216) * fix(tests): Migrate node tests from CJS to ESM This allows us to import (rather than require) chai, fixing failures caused by that package dropping suppport for CJS in chai v5.0.0. * fix(tests): Have mocha tests directly import chai Previously they relied on obtaining it from the global scope, but it's better if imports are explicit. * fix(tests): Remove broken load of chai as script Chai v5.0.0 no longer supports being loaded as a script, so this did nothing but emit an syntax error message on the console. * fix(tests): Migrate browser tests from CJS to ESM This allows us to import (rather than require) chai, fixing failures caused by chai no longer supporting CJS. * chore(tests): format --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Christopher Allen <cpcallen+git@google.com>
110 lines
3.5 KiB
JavaScript
110 lines
3.5 KiB
JavaScript
/**
|
|
* @license
|
|
* Copyright 2022 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import {assert} from '../../node_modules/chai/chai.js';
|
|
import {
|
|
sharedTestSetup,
|
|
sharedTestTeardown,
|
|
} from './test_helpers/setup_teardown.js';
|
|
|
|
suite('Touch', function () {
|
|
setup(function () {
|
|
sharedTestSetup.call(this);
|
|
});
|
|
|
|
teardown(function () {
|
|
Blockly.Touch.clearTouchIdentifier();
|
|
sharedTestTeardown.call(this);
|
|
});
|
|
|
|
suite('shouldHandleTouch', function () {
|
|
test('handles pointerdown event', function () {
|
|
const pointerEvent = new PointerEvent('pointerdown');
|
|
assert.isTrue(Blockly.Touch.shouldHandleEvent(pointerEvent));
|
|
});
|
|
|
|
test('handles multiple pointerdown events', function () {
|
|
const pointerEvent1 = new PointerEvent('pointerdown');
|
|
const pointerEvent2 = new PointerEvent('pointerdown');
|
|
Blockly.Touch.shouldHandleEvent(pointerEvent1);
|
|
assert.isTrue(Blockly.Touch.shouldHandleEvent(pointerEvent2));
|
|
});
|
|
|
|
test('does not handle pointerup if not tracking touch', function () {
|
|
const pointerEvent = new PointerEvent('pointerup');
|
|
assert.isFalse(Blockly.Touch.shouldHandleEvent(pointerEvent));
|
|
});
|
|
|
|
test('handles pointerup if already tracking a touch', function () {
|
|
const pointerdown = new PointerEvent('pointerdown');
|
|
const pointerup = new PointerEvent('pointerup');
|
|
// Register the pointerdown event first
|
|
Blockly.Touch.shouldHandleEvent(pointerdown);
|
|
assert.isTrue(Blockly.Touch.shouldHandleEvent(pointerup));
|
|
});
|
|
|
|
test('handles pointerdown if this is a new touch', function () {
|
|
const pointerdown = new PointerEvent('pointerdown', {
|
|
pointerId: 1,
|
|
pointerType: 'touch',
|
|
});
|
|
assert.isTrue(Blockly.Touch.shouldHandleEvent(pointerdown));
|
|
});
|
|
|
|
test('does not handle pointerdown if part of a different touch', function () {
|
|
const pointerdown1 = new PointerEvent('pointerdown', {
|
|
pointerId: 1,
|
|
pointerType: 'touch',
|
|
});
|
|
const pointerdown2 = new PointerEvent('pointerdown', {
|
|
pointerId: 2,
|
|
pointerType: 'touch',
|
|
});
|
|
Blockly.Touch.shouldHandleEvent(pointerdown1);
|
|
assert.isFalse(Blockly.Touch.shouldHandleEvent(pointerdown2));
|
|
});
|
|
|
|
test('does not handle pointerup if not tracking touch', function () {
|
|
const pointerup = new PointerEvent('pointerup', {
|
|
pointerId: 1,
|
|
pointerType: 'touch',
|
|
});
|
|
assert.isFalse(Blockly.Touch.shouldHandleEvent(pointerup));
|
|
});
|
|
|
|
test('handles pointerup if part of existing touch', function () {
|
|
const pointerdown = new PointerEvent('pointerdown', {
|
|
pointerId: 1,
|
|
pointerType: 'touch',
|
|
});
|
|
const pointerup = new PointerEvent('pointerdown', {
|
|
pointerId: 1,
|
|
pointerType: 'touch',
|
|
});
|
|
Blockly.Touch.shouldHandleEvent(pointerdown);
|
|
assert.isTrue(Blockly.Touch.shouldHandleEvent(pointerup));
|
|
});
|
|
});
|
|
|
|
suite('getTouchIdentifierFromEvent', function () {
|
|
test('is pointerId for mouse PointerEvents', function () {
|
|
const pointerdown = new PointerEvent('pointerdown', {
|
|
pointerId: 7,
|
|
pointerType: 'mouse',
|
|
});
|
|
assert.equal(Blockly.Touch.getTouchIdentifierFromEvent(pointerdown), 7);
|
|
});
|
|
|
|
test('is pointerId for touch PointerEvents', function () {
|
|
const pointerdown = new PointerEvent('pointerdown', {
|
|
pointerId: 42,
|
|
pointerType: 'touch',
|
|
});
|
|
assert.equal(Blockly.Touch.getTouchIdentifierFromEvent(pointerdown), 42);
|
|
});
|
|
});
|
|
});
|