Files
blockly/tests/mocha/blocks/loops_test.js
John Nesky cee7f916bb feat!: Invalid Blocks (#7958)
* feat: Invalid Blocks

* Rename the new json property from invalid to invalidReasons.

* Merged isValid into isEnabled.

* Minor fixes.

* More minor fixes.

* Reverting some stuff that didn't need to change.

* Addressing PR feedback.

* Update the BlockInfo interface to match State.

* Make BlockChange.disabledReason private.
2024-04-17 19:47:51 -07:00

56 lines
1.5 KiB
JavaScript

/**
* @license
* Copyright 2024 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import * as Blockly from '../../../build/src/core/blockly.js';
import {
sharedTestSetup,
sharedTestTeardown,
} from '../test_helpers/setup_teardown.js';
suite('Loops', function () {
setup(function () {
sharedTestSetup.call(this, {fireEventsNow: false});
this.workspace = Blockly.inject('blocklyDiv', {});
});
teardown(function () {
sharedTestTeardown.call(this);
});
suite('controls_flow_statements blocks', function () {
test('break block is invalid outside of loop block', function () {
const breakBlock = Blockly.serialization.blocks.append(
{'type': 'controls_flow_statements'},
this.workspace,
);
this.clock.runAll();
chai.assert.isFalse(
breakBlock.isEnabled(),
'Expected the break block to be disabled',
);
});
test('break block is valid inside of loop block', function () {
const loopBlock = Blockly.serialization.blocks.append(
{'type': 'controls_repeat'},
this.workspace,
);
const breakBlock = Blockly.serialization.blocks.append(
{'type': 'controls_flow_statements'},
this.workspace,
);
loopBlock
.getInput('DO')
.connection.connect(breakBlock.previousConnection);
this.clock.runAll();
chai.assert.isTrue(
breakBlock.isEnabled(),
'Expected the break block to be enabled',
);
});
});
});