mirror of
https://github.com/google/blockly.git
synced 2026-01-07 17:10:11 +01:00
213 lines
7.2 KiB
JavaScript
213 lines
7.2 KiB
JavaScript
/**
|
|
* @license
|
|
* Copyright 2019 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
goog.module('Blockly.test.fieldLabelSerialization');
|
|
|
|
const {createTestBlock, defineRowBlock, sharedTestSetup, sharedTestTeardown, workspaceTeardown} = goog.require('Blockly.test.helpers');
|
|
|
|
|
|
suite('Label Serializable Fields', function() {
|
|
setup(function() {
|
|
sharedTestSetup.call(this);
|
|
});
|
|
teardown(function() {
|
|
sharedTestTeardown.call(this);
|
|
});
|
|
/**
|
|
* Configuration for field tests with invalid values.
|
|
* @type {!Array<!FieldCreationTestCase>}
|
|
*/
|
|
let invalidValueTestCases = [
|
|
{title: 'Undefined', value: undefined},
|
|
{title: 'Null', value: null},
|
|
];
|
|
/**
|
|
* Configuration for field tests with valid values.
|
|
* @type {!Array<!FieldCreationTestCase>}
|
|
*/
|
|
let validValueTestCases = [
|
|
{title: 'String', value: 'value', expectedValue: 'value'},
|
|
{title: 'Boolean true', value: true, expectedValue: 'true'},
|
|
{title: 'Boolean false', value: false, expectedValue: 'false'},
|
|
{title: 'Number (Truthy)', value: 1, expectedValue: '1'},
|
|
{title: 'Number (Falsy)', value: 0, expectedValue: '0'},
|
|
{title: 'NaN', value: NaN, expectedValue: 'NaN'},
|
|
];
|
|
let addArgsAndJson = function(testCase) {
|
|
testCase.args = [testCase.value];
|
|
testCase.json = {'text': testCase.value};
|
|
};
|
|
invalidValueTestCases.forEach(addArgsAndJson);
|
|
validValueTestCases.forEach(addArgsAndJson);
|
|
|
|
/**
|
|
* The expected default value for the field being tested.
|
|
* @type {*}
|
|
*/
|
|
let defaultFieldValue = '';
|
|
/**
|
|
* Asserts that the field property values are set to default.
|
|
* @param {!Blockly.FieldLabelSerializable} field The field to check.
|
|
*/
|
|
let assertFieldDefault = function(field) {
|
|
testHelpers.assertFieldValue(field, defaultFieldValue);
|
|
};
|
|
/**
|
|
* Asserts that the field properties are correct based on the test case.
|
|
* @param {!Blockly.FieldLabelSerializable} field The field to check.
|
|
* @param {!FieldValueTestCase} testCase The test case.
|
|
*/
|
|
let validTestCaseAssertField = function(field, testCase) {
|
|
testHelpers.assertFieldValue(field, testCase.expectedValue);
|
|
};
|
|
|
|
testHelpers.runConstructorSuiteTests(
|
|
Blockly.FieldLabelSerializable, validValueTestCases,
|
|
invalidValueTestCases, validTestCaseAssertField, assertFieldDefault);
|
|
|
|
testHelpers.runFromJsonSuiteTests(
|
|
Blockly.FieldLabelSerializable, validValueTestCases, invalidValueTestCases,
|
|
validTestCaseAssertField, assertFieldDefault);
|
|
|
|
suite('setValue', function() {
|
|
suite('Empty -> New Value', function() {
|
|
setup(function() {
|
|
this.field = new Blockly.FieldLabelSerializable();
|
|
});
|
|
testHelpers.runSetValueTests(
|
|
validValueTestCases, invalidValueTestCases, defaultFieldValue);
|
|
test('With source block', function() {
|
|
this.field.setSourceBlock(createTestBlock());
|
|
this.field.setValue('value');
|
|
testHelpers.assertFieldValue(this.field, 'value');
|
|
});
|
|
});
|
|
suite('Value -> New Value', function() {
|
|
let initialValue = 'oldValue';
|
|
setup(function() {
|
|
this.field = new Blockly.FieldLabelSerializable(initialValue);
|
|
});
|
|
testHelpers.runSetValueTests(
|
|
validValueTestCases, invalidValueTestCases, initialValue);
|
|
test('With source block', function() {
|
|
this.field.setSourceBlock(createTestBlock());
|
|
this.field.setValue('value');
|
|
testHelpers.assertFieldValue(this.field, 'value');
|
|
});
|
|
});
|
|
});
|
|
|
|
suite('Customizations', function() {
|
|
function assertHasClass(labelField, cssClass) {
|
|
labelField.fieldGroup_ = Blockly.utils.dom.createSvgElement(
|
|
Blockly.utils.Svg.G, {}, null);
|
|
labelField.constants_ = {
|
|
FIELD_TEXT_BASELINE_Y: 13
|
|
};
|
|
labelField.initView();
|
|
chai.assert.isTrue(Blockly.utils.dom.hasClass(
|
|
labelField.textElement_, cssClass));
|
|
}
|
|
function assertDoesNotHaveClass(labelField, cssClass) {
|
|
labelField.fieldGroup_ = Blockly.utils.dom.createSvgElement(
|
|
Blockly.utils.Svg.G, {}, null);
|
|
labelField.constants_ = {
|
|
FIELD_TEXT_BASELINE_Y: 13
|
|
};
|
|
labelField.initView();
|
|
chai.assert.isFalse(Blockly.utils.dom.hasClass(
|
|
labelField.textElement_, cssClass));
|
|
}
|
|
test('JS Constructor', function() {
|
|
let field = new Blockly.FieldLabelSerializable('text', 'testClass');
|
|
assertHasClass(field, 'testClass');
|
|
});
|
|
test('JSON Definition', function() {
|
|
let field = Blockly.FieldLabelSerializable.fromJson({
|
|
class: 'testClass'
|
|
});
|
|
assertHasClass(field, 'testClass');
|
|
});
|
|
test('JS Configuration - Simple', function() {
|
|
let field = new Blockly.FieldLabelSerializable('text', null, {
|
|
class: 'testClass'
|
|
});
|
|
assertHasClass(field, 'testClass');
|
|
});
|
|
test('JS Configuration - Ignore', function() {
|
|
let field = new Blockly.FieldLabelSerializable('text', 'paramClass', {
|
|
class: 'configClass'
|
|
});
|
|
assertDoesNotHaveClass(field, 'paramClass');
|
|
assertHasClass(field, 'configClass');
|
|
});
|
|
test('JS Configuration - Ignore - \'\'', function() {
|
|
let field = new Blockly.FieldLabelSerializable('text', '', {
|
|
class: 'configClass'
|
|
});
|
|
assertHasClass(field, 'configClass');
|
|
});
|
|
test('JS Configuration - Ignore - Config \'\'', function() {
|
|
let field = new Blockly.FieldLabelSerializable('text', 'paramClass', {
|
|
class: ''
|
|
});
|
|
assertDoesNotHaveClass(field, 'paramClass');
|
|
});
|
|
suite('setClass', function() {
|
|
test('setClass', function() {
|
|
let field = new Blockly.FieldLabelSerializable();
|
|
field.fieldGroup_ = Blockly.utils.dom.createSvgElement(
|
|
Blockly.utils.Svg.G, {}, null);
|
|
field.constants_ = {
|
|
FIELD_TEXT_BASELINE_Y: 13
|
|
};
|
|
field.initView();
|
|
field.setClass('testClass');
|
|
// Don't call assertHasClass b/c we don't want to re-initialize.
|
|
chai.assert.isTrue(Blockly.utils.dom.hasClass(
|
|
field.textElement_, 'testClass'));
|
|
});
|
|
test('setClass Before Initialization', function() {
|
|
let field = new Blockly.FieldLabelSerializable();
|
|
field.setClass('testClass');
|
|
assertHasClass(field, 'testClass');
|
|
});
|
|
test('Remove Class', function() {
|
|
let field = new Blockly.FieldLabelSerializable('text', null, {
|
|
class: 'testClass'
|
|
});
|
|
assertHasClass(field, 'testClass');
|
|
field.setClass(null);
|
|
chai.assert.isFalse(Blockly.utils.dom.hasClass(
|
|
field.textElement_, 'testClass'));
|
|
});
|
|
});
|
|
});
|
|
|
|
suite('Serialization', function() {
|
|
setup(function() {
|
|
this.workspace = new Blockly.Workspace();
|
|
defineRowBlock();
|
|
|
|
this.assertValue = (value) => {
|
|
const block = this.workspace.newBlock('row_block');
|
|
const field = new Blockly.FieldLabelSerializable(value);
|
|
block.getInput('INPUT').appendField(field, 'LABEL');
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
chai.assert.deepEqual(jso['fields'], {'LABEL': value});
|
|
};
|
|
});
|
|
|
|
teardown(function() {
|
|
workspaceTeardown.call(this, this.workspace);
|
|
});
|
|
|
|
test('Simple', function() {
|
|
this.assertValue('test label');
|
|
});
|
|
});
|
|
});
|