mirror of
https://github.com/google/blockly.git
synced 2026-01-08 17:40:09 +01:00
348 lines
11 KiB
JavaScript
348 lines
11 KiB
JavaScript
/**
|
|
* @license
|
|
* Copyright 2021 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
goog.module('Blockly.test.jsoSerialization');
|
|
|
|
const {defineStackBlock, defineRowBlock, defineStatementBlock, createGenUidStubWithReturns, sharedTestSetup, sharedTestTeardown, workspaceTeardown} = goog.require('Blockly.test.helpers');
|
|
|
|
|
|
suite('JSO', function() {
|
|
setup(function() {
|
|
sharedTestSetup.call(this);
|
|
this.workspace = new Blockly.Workspace();
|
|
|
|
defineStackBlock();
|
|
defineRowBlock();
|
|
defineStatementBlock();
|
|
|
|
createGenUidStubWithReturns(new Array(10).fill().map((_, i) => 'id' + i));
|
|
});
|
|
|
|
teardown(function() {
|
|
workspaceTeardown.call(this, this.workspace);
|
|
sharedTestTeardown.call(this);
|
|
});
|
|
|
|
suite('Blocks', function() {
|
|
function assertProperty(obj, property, value) {
|
|
chai.assert.deepEqual(obj[property], value);
|
|
}
|
|
|
|
function assertNoProperty(obj, property) {
|
|
assertProperty(obj, property, undefined);
|
|
}
|
|
|
|
test('Null on insertionMarkers', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setInsertionMarker(true);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
chai.assert.isNull(jso);
|
|
});
|
|
|
|
test('Basic', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'type', 'row_block');
|
|
assertProperty(jso, 'id', 'id0');
|
|
});
|
|
|
|
suite('Attributes', function() {
|
|
suite('Collapsed', function() {
|
|
test('True', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setCollapsed(true);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'collapsed', true);
|
|
});
|
|
|
|
test('False', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setCollapsed(false);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'collapsed');
|
|
});
|
|
});
|
|
|
|
suite('Enabled', function() {
|
|
test('False', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setEnabled(false);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'enabled', false);
|
|
});
|
|
|
|
test('True', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setEnabled(true);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'enabled');
|
|
});
|
|
});
|
|
|
|
suite('Deletable', function() {
|
|
test('False', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setDeletable(false);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'deletable', false);
|
|
});
|
|
|
|
test('True', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setDeletable(true);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'deletable');
|
|
});
|
|
|
|
test('False and Shadow', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setDeletable(false);
|
|
block.setShadow(true);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'deletable');
|
|
});
|
|
});
|
|
|
|
suite('Movable', function() {
|
|
test('False', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setMovable(false);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'movable', false);
|
|
});
|
|
|
|
test('True', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setMovable(true);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'movable');
|
|
});
|
|
|
|
test('False and Shadow', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setMovable(false);
|
|
block.setShadow(true);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'movable');
|
|
});
|
|
});
|
|
|
|
suite('Editable', function() {
|
|
test('False', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setEditable(false);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'editable', false);
|
|
});
|
|
|
|
test('True', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.setEditable(true);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'editable');
|
|
});
|
|
});
|
|
|
|
suite('Inline', function() {
|
|
test('True', function() {
|
|
const block = this.workspace.newBlock('statement_block');
|
|
block.setInputsInline(true);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'inline', true);
|
|
});
|
|
|
|
test('False', function() {
|
|
const block = this.workspace.newBlock('statement_block');
|
|
block.setInputsInline(false);
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'inline', false);
|
|
});
|
|
|
|
test('undefined', function() {
|
|
const block = this.workspace.newBlock('statement_block');
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'inline');
|
|
});
|
|
|
|
test('True, matching default', function() {
|
|
const block = this.workspace.newBlock('statement_block');
|
|
block.setInputsInline(true);
|
|
block.inputsInlineDefault = true;
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'inline');
|
|
});
|
|
|
|
test('False, matching default', function() {
|
|
const block = this.workspace.newBlock('statement_block');
|
|
block.setInputsInline(false);
|
|
block.inputsInlineDefault = false;
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'inline');
|
|
});
|
|
});
|
|
|
|
suite('Data', function() {
|
|
test('No data', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'data');
|
|
});
|
|
|
|
test('With data', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.data = 'some data';
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'data', 'some data');
|
|
});
|
|
});
|
|
});
|
|
|
|
suite('Coords', function() {
|
|
test('No coordinates', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertNoProperty(jso, 'x');
|
|
assertNoProperty(jso, 'y');
|
|
});
|
|
|
|
test('Simple', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.moveBy(42, 42);
|
|
const jso =
|
|
Blockly.serialization.blocks.save(block, {addCoordinates: true});
|
|
assertProperty(jso, 'x', 42);
|
|
assertProperty(jso, 'y', 42);
|
|
});
|
|
|
|
test('Negative', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.moveBy(-42, -42);
|
|
const jso =
|
|
Blockly.serialization.blocks.save(block, {addCoordinates: true});
|
|
assertProperty(jso, 'x', -42);
|
|
assertProperty(jso, 'y', -42);
|
|
});
|
|
|
|
test('Zero', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
const jso =
|
|
Blockly.serialization.blocks.save(block, {addCoordinates: true});
|
|
assertProperty(jso, 'x', 0);
|
|
assertProperty(jso, 'y', 0);
|
|
});
|
|
});
|
|
|
|
// Mutators.
|
|
suite('Extra state', function() {
|
|
test('Simple value', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.saveExtraState = function() {
|
|
return 'some extra state';
|
|
};
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'extraState', 'some extra state');
|
|
});
|
|
|
|
test('Object', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.saveExtraState = function() {
|
|
return {
|
|
'extra1': 'state1',
|
|
'extra2': 42,
|
|
'extra3': true,
|
|
};
|
|
};
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'extraState', {
|
|
'extra1': 'state1',
|
|
'extra2': 42,
|
|
'extra3': true,
|
|
});
|
|
});
|
|
|
|
test('Array', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.saveExtraState = function() {
|
|
return ['state1', 42, true];
|
|
};
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'extraState', ['state1', 42, true]);
|
|
});
|
|
});
|
|
|
|
suite('Fields', function() {
|
|
class StringStateField extends Blockly.Field {
|
|
constructor(value, validator = undefined, config = undefined) {
|
|
super(value, validator, config);
|
|
this.SERIALIZABLE = true;
|
|
}
|
|
|
|
saveState() {
|
|
return 'some state';
|
|
}
|
|
}
|
|
|
|
class ObjectStateField extends Blockly.Field {
|
|
constructor(value, validator = undefined, config = undefined) {
|
|
super(value, validator, config);
|
|
this.SERIALIZABLE = true;
|
|
}
|
|
|
|
saveState() {
|
|
return {
|
|
'prop1': 'state1',
|
|
'prop2': 42,
|
|
'prop3': true,
|
|
};
|
|
}
|
|
}
|
|
|
|
class ArrayStateField extends Blockly.Field {
|
|
constructor(value, validator = undefined, config = undefined) {
|
|
super(value, validator, config);
|
|
this.SERIALIZABLE = true;
|
|
}
|
|
|
|
saveState() {
|
|
return ['state1', 42, true];
|
|
}
|
|
}
|
|
|
|
class XmlStateField extends Blockly.Field {
|
|
constructor(value, validator = undefined, config = undefined) {
|
|
super(value, validator, config);
|
|
this.SERIALIZABLE = true;
|
|
}
|
|
}
|
|
|
|
test('Simple value', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.getInput('INPUT').appendField(new StringStateField(''), 'FIELD');
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'fields', {'FIELD': 'some state'});
|
|
});
|
|
|
|
test('Object', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.getInput('INPUT').appendField(new ObjectStateField(''), 'FIELD');
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'fields', {'FIELD': {
|
|
'prop1': 'state1',
|
|
'prop2': 42,
|
|
'prop3': true,
|
|
}});
|
|
});
|
|
|
|
test('Array', function() {
|
|
const block = this.workspace.newBlock('row_block');
|
|
block.getInput('INPUT').appendField(new ArrayStateField(''), 'FIELD');
|
|
const jso = Blockly.serialization.blocks.save(block);
|
|
assertProperty(jso, 'fields', {'FIELD': ['state1', 42, true]});
|
|
});
|
|
});
|
|
});
|
|
});
|