Files
blockly/tests/mocha/theme_test.js
dependabot[bot] bfb5b1dd49 chore(deps): Bump chai from 4.3.10 to 5.1.1 (#8092)
* 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>
2024-06-17 16:48:21 +01:00

308 lines
8.1 KiB
JavaScript

/**
* @license
* Copyright 2019 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import {assert} from '../../node_modules/chai/chai.js';
import {assertEventFired} from './test_helpers/events.js';
import * as eventUtils from '../../build/src/core/events/utils.js';
import {
sharedTestSetup,
sharedTestTeardown,
workspaceTeardown,
} from './test_helpers/setup_teardown.js';
suite('Theme', function () {
setup(function () {
sharedTestSetup.call(this);
});
teardown(function () {
sharedTestTeardown.call(this);
// Clear all registered themes.
Blockly.registry.TEST_ONLY.typeMap['theme'] = {};
});
function defineThemeTestBlocks() {
Blockly.defineBlocksWithJsonArray([
{
'type': 'stack_block',
'message0': '',
'previousStatement': null,
'nextStatement': null,
},
{
'type': 'row_block',
'message0': '%1',
'args0': [
{
'type': 'input_value',
'name': 'INPUT',
},
],
'output': null,
},
]);
}
function createBlockStyles() {
return {
'styleOne': {
'colourPrimary': '#aaaaaa',
'colourSecondary': '#bbbbbb',
'colourTertiary': '#cccccc',
'hat': 'cap',
},
};
}
function createMultipleBlockStyles() {
return {
'styleOne': {
'colourPrimary': '#aaaaaa',
'colourSecondary': '#bbbbbb',
'colourTertiary': '#cccccc',
'hat': 'cap',
},
'styleTwo': {
'colourPrimary': '#000000',
'colourSecondary': '#999999',
'colourTertiary': '#4d4d4d',
'hat': '',
},
};
}
function stringifyAndCompare(val1, val2) {
const stringVal1 = JSON.stringify(val1);
const stringVal2 = JSON.stringify(val2);
assert.equal(stringVal1, stringVal2);
}
test('Set All BlockStyles', function () {
const theme = new Blockly.Theme('test', createBlockStyles());
stringifyAndCompare(createBlockStyles(), theme.blockStyles);
const blockStyles = createMultipleBlockStyles();
for (const key in blockStyles) {
theme.blockStyles[key] = blockStyles[key];
}
stringifyAndCompare(createMultipleBlockStyles(), theme.blockStyles);
});
test('Get All BlockStyles', function () {
const theme = new Blockly.Theme('test', createMultipleBlockStyles());
const allBlocks = theme.blockStyles;
stringifyAndCompare(createMultipleBlockStyles(), allBlocks);
});
test('Get BlockStyles', function () {
const theme = new Blockly.Theme('test', createBlockStyles());
const blockStyle = theme.blockStyles['styleOne'];
stringifyAndCompare(blockStyle, createBlockStyles().styleOne);
});
test('Set BlockStyle Update', function () {
const theme = new Blockly.Theme('test', createBlockStyles());
const blockStyle = createBlockStyles();
blockStyle.styleOne.colourPrimary = '#00ff00';
theme.blockStyles['styleOne'] = blockStyle.styleOne;
stringifyAndCompare(theme.blockStyles, blockStyle);
});
test('Set BlockStyle Add', function () {
const theme = new Blockly.Theme('test', createBlockStyles());
const blockStyle = createMultipleBlockStyles();
theme.blockStyles['styleTwo'] = blockStyle.styleTwo;
stringifyAndCompare(theme.blockStyles, blockStyle);
});
test('Set Theme', function () {
defineThemeTestBlocks();
let workspace;
try {
const blockStyles = createBlockStyles();
const theme = new Blockly.Theme('themeName', blockStyles);
workspace = Blockly.inject('blocklyDiv', {});
const blockA = workspace.newBlock('stack_block');
blockA.setStyle = function () {
this.styleName_ = 'styleTwo';
};
const refreshToolboxSelectionStub = sinon.stub(
workspace,
'refreshToolboxSelection',
);
blockA.styleName_ = 'styleOne';
workspace.setTheme(theme);
// Checks that the theme was set correctly on Blockly namespace
stringifyAndCompare(workspace.getTheme(), theme);
// Checks that the setTheme function was called on the block
assert.equal(blockA.getStyleName(), 'styleTwo');
// Checks that the toolbox refreshed method was called
sinon.assert.calledOnce(refreshToolboxSelectionStub);
assertEventFired(
this.eventsFireStub,
Blockly.Events.ThemeChange,
{themeName: 'themeName', type: eventUtils.THEME_CHANGE},
workspace.id,
);
} finally {
workspaceTeardown.call(this, workspace);
}
});
suite('Validate block styles', function () {
setup(function () {
this.constants = new Blockly.blockRendering.ConstantProvider();
});
test('Null', function () {
const inputStyle = null;
const expectedOutput = {
'colourPrimary': '#000000',
'colourSecondary': '#999999',
'colourTertiary': '#4d4d4d',
'hat': '',
};
stringifyAndCompare(
this.constants.validatedBlockStyle_(inputStyle),
expectedOutput,
);
});
test('Empty', function () {
const inputStyle = {};
const expectedOutput = {
'colourPrimary': '#000000',
'colourSecondary': '#999999',
'colourTertiary': '#4d4d4d',
'hat': '',
};
stringifyAndCompare(
this.constants.validatedBlockStyle_(inputStyle),
expectedOutput,
);
});
test('Incomplete hex', function () {
const inputStyle = {
'colourPrimary': '#012345',
};
const expectedOutput = {
'colourPrimary': '#012345',
'colourSecondary': '#99a7b5',
'colourTertiary': '#4d657d',
'hat': '',
};
stringifyAndCompare(
this.constants.validatedBlockStyle_(inputStyle),
expectedOutput,
);
});
test('Complete hex', function () {
const inputStyle = {
'colourPrimary': '#aaaaaa',
'colourSecondary': '#bbbbbb',
'colourTertiary': '#cccccc',
'hat': 'cap',
};
const expectedOutput = {
'colourPrimary': '#aaaaaa',
'colourSecondary': '#bbbbbb',
'colourTertiary': '#cccccc',
'hat': 'cap',
};
stringifyAndCompare(
this.constants.validatedBlockStyle_(inputStyle),
expectedOutput,
);
});
test('Complete hue', function () {
const inputStyle = {
'colourPrimary': '20',
'colourSecondary': '40',
'colourTertiary': '60',
};
const expectedOutput = {
'colourPrimary': '#a5745b',
'colourSecondary': '#a58c5b',
'colourTertiary': '#a5a55b',
'hat': '',
};
stringifyAndCompare(
this.constants.validatedBlockStyle_(inputStyle),
expectedOutput,
);
});
test('Incomplete hue', function () {
const inputStyle = {
'colourPrimary': '20',
};
const expectedOutput = {
'colourPrimary': '#a5745b',
'colourSecondary': '#dbc7bd',
'colourTertiary': '#c09e8c',
'hat': '',
};
stringifyAndCompare(
this.constants.validatedBlockStyle_(inputStyle),
expectedOutput,
);
});
test('Complete css colour name', function () {
const inputStyle = {
'colourPrimary': 'red',
'colourSecondary': 'white',
'colourTertiary': 'blue',
};
const expectedOutput = {
'colourPrimary': '#ff0000',
'colourSecondary': '#ffffff',
'colourTertiary': '#0000ff',
'hat': '',
};
stringifyAndCompare(
this.constants.validatedBlockStyle_(inputStyle),
expectedOutput,
);
});
test('Incomplete css colour name', function () {
const inputStyle = {
'colourPrimary': 'black',
};
const expectedOutput = {
'colourPrimary': '#000000',
'colourSecondary': '#999999',
'colourTertiary': '#4d4d4d',
'hat': '',
};
stringifyAndCompare(
this.constants.validatedBlockStyle_(inputStyle),
expectedOutput,
);
});
});
suite('defineTheme', function () {
test('Normalizes to lowercase', function () {
const theme = Blockly.Theme.defineTheme('TEST', {});
assert.equal(theme.name, 'test');
});
});
});