mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2025-01-12 07:45:41 -05:00
140094a7ad
This involves adding a new opcode, event_whenstageclicked, and adding a method to the blocks container to update the opcode pair depending on whether the target is the stage. This method is then called in two places: first after the sb2 import parses the blocks (not done in the sb2 parsing itself because no other blocks are target specific) and then again when blocks are shared between targets. Also added tests for the block container method, and a fixture project that tests the opcode splitting on sb2 import.
93 lines
3.2 KiB
JavaScript
93 lines
3.2 KiB
JavaScript
const path = require('path');
|
|
const test = require('tap').test;
|
|
const extract = require('../fixtures/extract');
|
|
|
|
const RenderedTarget = require('../../src/sprites/rendered-target');
|
|
const Runtime = require('../../src/engine/runtime');
|
|
const sb2 = require('../../src/serialization/sb2');
|
|
|
|
test('spec', t => {
|
|
t.type(sb2, 'object');
|
|
t.type(sb2.deserialize, 'function');
|
|
t.end();
|
|
});
|
|
|
|
test('default', t => {
|
|
// Get SB2 JSON (string)
|
|
const uri = path.resolve(__dirname, '../fixtures/default.sb2');
|
|
const file = extract(uri);
|
|
const json = JSON.parse(file);
|
|
|
|
// Create runtime instance & load SB2 into it
|
|
const rt = new Runtime();
|
|
sb2.deserialize(json, rt).then(({targets}) => {
|
|
// Test
|
|
t.type(file, 'string');
|
|
t.type(json, 'object');
|
|
t.type(rt, 'object');
|
|
t.type(targets, 'object');
|
|
|
|
t.ok(targets[0] instanceof RenderedTarget);
|
|
t.type(targets[0].id, 'string');
|
|
t.type(targets[0].blocks, 'object');
|
|
t.type(targets[0].variables, 'object');
|
|
t.type(targets[0].lists, 'object');
|
|
|
|
t.equal(targets[0].isOriginal, true);
|
|
t.equal(targets[0].currentCostume, 0);
|
|
t.equal(targets[0].isOriginal, true);
|
|
t.equal(targets[0].isStage, true);
|
|
|
|
t.ok(targets[1] instanceof RenderedTarget);
|
|
t.type(targets[1].id, 'string');
|
|
t.type(targets[1].blocks, 'object');
|
|
t.type(targets[1].variables, 'object');
|
|
t.type(targets[1].lists, 'object');
|
|
|
|
t.equal(targets[1].isOriginal, true);
|
|
t.equal(targets[1].currentCostume, 0);
|
|
t.equal(targets[1].isOriginal, true);
|
|
t.equal(targets[1].isStage, false);
|
|
t.end();
|
|
});
|
|
});
|
|
|
|
test('data scoping', t => {
|
|
// Get SB2 JSON (string)
|
|
const uri = path.resolve(__dirname, '../fixtures/data.sb2');
|
|
const file = extract(uri);
|
|
const json = JSON.parse(file);
|
|
|
|
// Create runtime instance & load SB2 into it
|
|
const rt = new Runtime();
|
|
sb2.deserialize(json, rt).then(({targets}) => {
|
|
const globalVariableIds = Object.keys(targets[0].variables);
|
|
const localVariableIds = Object.keys(targets[1].variables);
|
|
t.equal(targets[0].variables[globalVariableIds[0]].name, 'foo');
|
|
t.equal(targets[1].variables[localVariableIds[0]].name, 'local');
|
|
t.end();
|
|
});
|
|
});
|
|
|
|
test('whenclicked blocks imported separately', t => {
|
|
// This sb2 fixture has a single "whenClicked" block on both sprite and stage
|
|
const uri = path.resolve(__dirname, '../fixtures/when-clicked.sb2');
|
|
const file = extract(uri);
|
|
const json = JSON.parse(file);
|
|
|
|
// Create runtime instance & load SB2 into it
|
|
const rt = new Runtime();
|
|
sb2.deserialize(json, rt).then(({targets}) => {
|
|
const stage = targets[0];
|
|
t.equal(stage.isStage, true); // Make sure we have the correct target
|
|
const stageOpcode = stage.blocks.getBlock(stage.blocks.getScripts()[0]).opcode;
|
|
t.equal(stageOpcode, 'event_whenstageclicked');
|
|
|
|
const sprite = targets[1];
|
|
t.equal(sprite.isStage, false); // Make sure we have the correct target
|
|
const spriteOpcode = sprite.blocks.getBlock(sprite.blocks.getScripts()[0]).opcode;
|
|
t.equal(spriteOpcode, 'event_whenthisspriteclicked');
|
|
|
|
t.end();
|
|
});
|
|
});
|