Add tests and update core example to handle stage being undefined.

This commit is contained in:
Karishma Chadha 2019-03-22 12:13:37 -04:00
parent 0e710ba3d9
commit 30c9b7fd84
3 changed files with 68 additions and 17 deletions

View file

@ -36,7 +36,8 @@ class Scratch3CoreExample {
* @returns {string} The name of the first target in the project. * @returns {string} The name of the first target in the project.
*/ */
exampleOpcode () { exampleOpcode () {
return this.runtime.getTargetForStage().getName(); const stage = this.runtime.getTargetForStage();
return stage ? stage.getName() : 'no stage yet';
} }
} }

View file

@ -4,6 +4,9 @@ const Worker = require('tiny-worker');
const dispatch = require('../../src/dispatch/central-dispatch'); const dispatch = require('../../src/dispatch/central-dispatch');
const VirtualMachine = require('../../src/virtual-machine'); const VirtualMachine = require('../../src/virtual-machine');
const Sprite = require('../../src/sprites/sprite');
const RenderedTarget = require('../../src/sprites/rendered-target');
// By default Central Dispatch works with the Worker class built into the browser. Tell it to use TinyWorker instead. // By default Central Dispatch works with the Worker class built into the browser. Tell it to use TinyWorker instead.
dispatch.workerClass = Worker; dispatch.workerClass = Worker;
@ -52,23 +55,49 @@ test('internal extension', t => {
t.ok(extension.status.constructorCalled); t.ok(extension.status.constructorCalled);
t.notOk(extension.status.getInfoCalled); t.notOk(extension.status.getInfoCalled);
return vm.extensionManager._registerInternalExtension(extension).then(() => { vm.extensionManager._registerInternalExtension(extension);
t.ok(extension.status.getInfoCalled); t.ok(extension.status.getInfoCalled);
const func = vm.runtime.getOpcodeFunction('testInternalExtension_go'); const func = vm.runtime.getOpcodeFunction('testInternalExtension_go');
t.type(func, 'function'); t.type(func, 'function');
t.notOk(extension.status.goCalled); t.notOk(extension.status.goCalled);
func(); func();
t.ok(extension.status.goCalled); t.ok(extension.status.goCalled);
// There should be 2 menus - one is an array, one is the function to call. // There should be 2 menus - one is an array, one is the function to call.
t.equal(vm.runtime._blockInfo[0].menus.length, 2); t.equal(vm.runtime._blockInfo[0].menus.length, 2);
// First menu has 3 items. // First menu has 3 items.
t.equal( t.equal(
vm.runtime._blockInfo[0].menus[0].json.args0[0].options.length, 3); vm.runtime._blockInfo[0].menus[0].json.args0[0].options.length, 3);
// Second menu is a dynamic menu and therefore should be a function. // Second menu is a dynamic menu and therefore should be a function.
t.type( t.type(
vm.runtime._blockInfo[0].menus[1].json.args0[0].options, 'function'); vm.runtime._blockInfo[0].menus[1].json.args0[0].options, 'function');
});
t.end();
});
test('load sync', t => {
const vm = new VirtualMachine();
vm.extensionManager.loadExtensionIdSync('coreExample');
t.ok(vm.extensionManager.isExtensionLoaded('coreExample'));
t.equal(vm.runtime._blockInfo.length, 1);
t.equal(vm.runtime._blockInfo[0].blocks.length, 1);
t.type(vm.runtime._blockInfo[0].blocks[0].info, 'object');
t.equal(vm.runtime._blockInfo[0].blocks[0].info.opcode, 'exampleOpcode');
t.equal(vm.runtime._blockInfo[0].blocks[0].info.blockType, 'reporter');
// Test the opcode function
t.equal(vm.runtime._blockInfo[0].blocks[0].info.func(), 'no stage yet');
const sprite = new Sprite(null, vm.runtime);
sprite.name = 'Stage';
const stage = new RenderedTarget(sprite, vm.runtime);
stage.isStage = true;
vm.runtime.targets = [stage];
t.equal(vm.runtime._blockInfo[0].blocks[0].info.func(), 'Stage');
t.end();
}); });

View file

@ -62,3 +62,24 @@ test('remote', t => {
.then(() => runServiceTest('RemoteDispatchTest', t), e => t.fail(e)) .then(() => runServiceTest('RemoteDispatchTest', t), e => t.fail(e))
.then(() => dispatch._remoteCall(worker, 'dispatch', 'terminate'), e => t.fail(e)); .then(() => dispatch._remoteCall(worker, 'dispatch', 'terminate'), e => t.fail(e));
}); });
test('local, sync', t => {
dispatch.setServiceSync('SyncDispatchTest', new DispatchTestService());
const a = dispatch.callSync('SyncDispatchTest', 'returnFortyTwo');
t.equal(a, 42);
const b = dispatch.callSync('SyncDispatchTest', 'doubleArgument', 9);
t.equal(b, 18);
const c = dispatch.callSync('SyncDispatchTest', 'doubleArgument', 123);
t.equal(c, 246);
try {
dispatch.callSync('SyncDispatchTest', 'throwException');
} catch (e) {
t.equal(e.message, 'This is a test exception thrown by DispatchTest');
}
t.end();
});