Files
blockly/tests/mocha/tooltip_test.js
Aaron Dodson 90cb965e7c refactor: Migrate to PointerEvents (#6598)
* refactor: Remove checks for PointerEvent support.

* refactor: Deprecate and remove calls to splitEventByTouches.

* refactor: Deprecate and remove calls to setClientFromTouch().

* refactor: Use PointerEvent in place of Event/MouseEvent/TouchEvent/PseudoEvent.

* refactor: Update references to mouse/touch events in code and documentation to reference pointer events.

* refactor: Merge Gesture and TouchGesture

* chore: clang-format changed files

* refactor: Bind and expect PointerEvents instead of MouseEvents.

* refactor: Rename TouchGesture to Gesture.

* fix: Fix test failures.

* chore: clang-format changed files.

* fix: Fix errant _ from merging

* refactor: Clean up dead code in browser_events.ts.

* chore: Update version in deprecation notices to reflect release schedule

* fix: Fixed a bug that caused the browser context menu to not be suppressed in Chrome.

* fix: Re-export Gesture as TouchGesture for backwards compatibility.

* refactor: Deprecate and remove uses of opt_noPreventDefault.

* chore: Fix error message in gesture.ts.

* chore: Removed obsolete todo.
2022-12-05 11:27:52 -08:00

266 lines
6.9 KiB
JavaScript

/**
* @license
* Copyright 2020 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
goog.declareModuleId('Blockly.test.tooltip');
import {sharedTestSetup, sharedTestTeardown, workspaceTeardown} from './test_helpers/setup_teardown.js';
suite('Tooltip', function() {
setup(function() {
sharedTestSetup.call(this);
this.workspace = new Blockly.Workspace();
Blockly.defineBlocksWithJsonArray([
{
'type': 'test_block',
'message0': '%1',
'args0': [
{
'type': 'field_input',
'name': 'FIELD',
},
],
},
]);
});
teardown(function() {
delete Blockly.Blocks['test_block'];
sharedTestTeardown.call(this);
});
suite('Custom Tooltip', function() {
setup(function() {
this.renderedWorkspace = Blockly.inject('blocklyDiv', {});
});
teardown(function() {
workspaceTeardown.call(this, this.renderedWorkspace);
});
test('Custom function is called', function() {
// Custom tooltip function is registered and should be called when mouse
// events are fired.
let wasCalled = false;
const customFn = function() {
wasCalled = true;
};
Blockly.Tooltip.setCustomTooltip(customFn);
this.block = this.renderedWorkspace.newBlock('test_block');
this.block.setTooltip('Test Tooltip');
// Fire pointer events directly on the relevant SVG.
this.block.pathObject.svgPath.dispatchEvent(
new PointerEvent('pointerover'));
this.block.pathObject.svgPath.dispatchEvent(new PointerEvent('pointermove'));
this.clock.runAll();
chai.assert.isTrue(
wasCalled, 'Expected custom tooltip function to have been called');
});
});
suite('set/getTooltip', function() {
const tooltipText = 'testTooltip';
function assertTooltip(obj) {
chai.assert.equal(obj.getTooltip(), tooltipText);
}
function setStringTooltip(obj) {
obj.setTooltip(tooltipText);
}
function setFunctionTooltip(obj) {
obj.setTooltip(() => tooltipText);
}
function setNestedFunctionTooltip(obj) {
function nestFunction(fn, count) {
if (!count) {
return fn;
}
return () => nestFunction(fn, --count);
}
obj.setTooltip(nestFunction(() => tooltipText, 5));
}
function setFunctionReturningObjectTooltip(obj) {
obj.setTooltip(() => {
return {
tooltip: tooltipText,
};
});
}
function setObjectTooltip(obj) {
obj.setTooltip({tooltip: tooltipText});
}
suite('Headless Blocks', function() {
setup(function() {
this.block = this.workspace.newBlock('test_block');
});
test('String', function() {
setStringTooltip(this.block);
assertTooltip(this.block);
});
test('Function', function() {
setFunctionTooltip(this.block);
assertTooltip(this.block);
});
test('Nested Function', function() {
setNestedFunctionTooltip(this.block);
assertTooltip(this.block);
});
test('Function returning object', function() {
setFunctionReturningObjectTooltip(this.block);
chai.assert.throws(
this.block.getTooltip.bind(this.block),
'Tooltip function must return a string.');
});
test('Object', function() {
setObjectTooltip(this.block);
assertTooltip(this.block);
});
});
suite('Rendered Blocks', function() {
setup(function() {
this.renderedWorkspace = Blockly.inject('blocklyDiv');
this.block = this.renderedWorkspace.newBlock('test_block');
this.block.initSvg();
this.block.render();
});
teardown(function() {
workspaceTeardown.call(this, this.renderedWorkspace);
});
test('String', function() {
setStringTooltip(this.block);
assertTooltip(this.block);
});
test('Function', function() {
setFunctionTooltip(this.block);
assertTooltip(this.block);
});
test('Nested Function', function() {
setNestedFunctionTooltip(this.block);
assertTooltip(this.block);
});
test('Function returning object', function() {
setFunctionReturningObjectTooltip(this.block);
chai.assert.throws(
this.block.getTooltip.bind(this.block),
'Tooltip function must return a string.');
});
test('Object', function() {
setObjectTooltip(this.block);
assertTooltip(this.block);
});
});
suite('Headless Fields', function() {
setup(function() {
this.block = this.workspace.newBlock('test_block');
this.field = this.block.getField('FIELD');
});
test('String', function() {
setStringTooltip(this.field);
assertTooltip(this.field);
});
test('Function', function() {
setFunctionTooltip(this.field);
assertTooltip(this.field);
});
test('Nested Function', function() {
setNestedFunctionTooltip(this.field);
assertTooltip(this.field);
});
test('Function returning object', function() {
setFunctionReturningObjectTooltip(this.field);
chai.assert.throws(
this.field.getTooltip.bind(this.field),
'Tooltip function must return a string.');
});
test('Object', function() {
setObjectTooltip(this.field);
assertTooltip(this.field);
});
test('Null', function() {
setStringTooltip(this.block);
this.field.setTooltip(null);
assertTooltip(this.field);
});
});
suite('Rendered Fields', function() {
setup(function() {
this.renderedWorkspace = Blockly.inject('blocklyDiv');
this.block = this.renderedWorkspace.newBlock('test_block');
this.block.initSvg();
this.block.render();
this.field = this.block.getField('FIELD');
});
teardown(function() {
workspaceTeardown.call(this, this.renderedWorkspace);
});
test('String', function() {
setStringTooltip(this.field);
assertTooltip(this.field);
});
test('Function', function() {
setFunctionTooltip(this.field);
assertTooltip(this.field);
});
test('Nested Function', function() {
setNestedFunctionTooltip(this.field);
assertTooltip(this.field);
});
test('Function returning object', function() {
setFunctionReturningObjectTooltip(this.field);
chai.assert.throws(
this.field.getTooltip.bind(this.field),
'Tooltip function must return a string.');
});
test('Object', function() {
setObjectTooltip(this.field);
assertTooltip(this.field);
});
test('Null', function() {
setStringTooltip(this.block);
this.field.setTooltip(null);
assertTooltip(this.field);
});
});
});
});