mirror of
https://github.com/google/blockly.git
synced 2026-01-07 00:50:27 +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>
117 lines
3.2 KiB
JavaScript
117 lines
3.2 KiB
JavaScript
/**
|
|
* @license
|
|
* Copyright 2019 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('DropDownDiv', function () {
|
|
suite('Positioning', function () {
|
|
setup(function () {
|
|
sharedTestSetup.call(this);
|
|
this.boundsStub = sinon
|
|
.stub(Blockly.DropDownDiv.TEST_ONLY, 'getBoundsInfo')
|
|
.returns({
|
|
left: 0,
|
|
right: 100,
|
|
top: 0,
|
|
bottom: 100,
|
|
width: 100,
|
|
height: 100,
|
|
});
|
|
this.sizeStub = sinon
|
|
.stub(Blockly.utils.style.TEST_ONLY, 'getSizeInternal')
|
|
.returns({
|
|
width: 60,
|
|
height: 60,
|
|
});
|
|
this.clientHeightStub = sinon
|
|
.stub(document.documentElement, 'clientHeight')
|
|
.get(function () {
|
|
return 1000;
|
|
});
|
|
this.clientTopStub = sinon
|
|
.stub(document.documentElement, 'clientTop')
|
|
.get(function () {
|
|
return 0;
|
|
});
|
|
});
|
|
teardown(function () {
|
|
sharedTestTeardown.call(this);
|
|
});
|
|
test('Below, in Bounds', function () {
|
|
const metrics = Blockly.DropDownDiv.TEST_ONLY.getPositionMetrics(
|
|
50,
|
|
0,
|
|
50,
|
|
-10,
|
|
);
|
|
// "Above" in value actually means below in render.
|
|
assert.isAtLeast(metrics.initialY, 0);
|
|
assert.isAbove(metrics.finalY, 0);
|
|
assert.isTrue(metrics.arrowVisible);
|
|
assert.isTrue(metrics.arrowAtTop);
|
|
});
|
|
test('Above, in Bounds', function () {
|
|
const metrics = Blockly.DropDownDiv.TEST_ONLY.getPositionMetrics(
|
|
50,
|
|
100,
|
|
50,
|
|
90,
|
|
);
|
|
// "Below" in value actually means above in render.
|
|
assert.isAtMost(metrics.initialY, 100);
|
|
assert.isBelow(metrics.finalY, 100);
|
|
assert.isTrue(metrics.arrowVisible);
|
|
assert.isFalse(metrics.arrowAtTop);
|
|
});
|
|
test('Below, out of Bounds', function () {
|
|
const metrics = Blockly.DropDownDiv.TEST_ONLY.getPositionMetrics(
|
|
50,
|
|
60,
|
|
50,
|
|
50,
|
|
);
|
|
// "Above" in value actually means below in render.
|
|
assert.isAtLeast(metrics.initialY, 60);
|
|
assert.isAbove(metrics.finalY, 60);
|
|
assert.isTrue(metrics.arrowVisible);
|
|
assert.isTrue(metrics.arrowAtTop);
|
|
});
|
|
test('Above, in Bounds', function () {
|
|
const metrics = Blockly.DropDownDiv.TEST_ONLY.getPositionMetrics(
|
|
50,
|
|
100,
|
|
50,
|
|
90,
|
|
);
|
|
// "Below" in value actually means above in render.
|
|
assert.isAtMost(metrics.initialY, 100);
|
|
assert.isBelow(metrics.finalY, 100);
|
|
assert.isTrue(metrics.arrowVisible);
|
|
assert.isFalse(metrics.arrowAtTop);
|
|
});
|
|
test('No Solution, Render At Top', function () {
|
|
this.clientHeightStub.get(function () {
|
|
return 100;
|
|
});
|
|
const metrics = Blockly.DropDownDiv.TEST_ONLY.getPositionMetrics(
|
|
50,
|
|
60,
|
|
50,
|
|
50,
|
|
);
|
|
// "Above" in value actually means below in render.
|
|
assert.equal(metrics.initialY, 0);
|
|
assert.equal(metrics.finalY, 0);
|
|
assert.isFalse(metrics.arrowVisible);
|
|
assert.isNotOk(metrics.arrowAtTop);
|
|
});
|
|
});
|
|
});
|