mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2025-01-12 07:45:41 -05:00
05f8692300
As part of simplifying the CI setup I plan to not explicitly specify `--jobs=4` to `tap` going forward. Upgrading to a newer version of `tap` means that it will automatically parallelize jobs according to available CPU count, which should be better anyway. Only one of our tests was incompatible with newer versions of `tap`, so this commit includes a compatibility fix there. Also, by default newer versions of `tap` calculate coverage and consider the test run to fail if below the configured thresholds. The default is 100% coverage and we're not there, so I adjusted the thresholds to match where we're at for now. We can ratchet those up over time.
63 lines
1.7 KiB
JavaScript
63 lines
1.7 KiB
JavaScript
const newBlockIds = require('../../src/util/new-block-ids');
|
|
const simpleStack = require('../fixtures/simple-stack');
|
|
const tap = require('tap');
|
|
const test = tap.test;
|
|
|
|
let originals;
|
|
let newBlocks;
|
|
|
|
tap.beforeEach(() => {
|
|
originals = simpleStack;
|
|
// Will be mutated so make a copy first
|
|
newBlocks = JSON.parse(JSON.stringify(simpleStack));
|
|
newBlockIds(newBlocks);
|
|
});
|
|
|
|
|
|
/**
|
|
* The structure of the simple stack is:
|
|
* moveTo (looks_size) -> stopAllSounds
|
|
* The list of blocks is
|
|
* 0: moveTo (TO input block: 1, shadow: 2)
|
|
* 1: looks_size (parent: 0)
|
|
* 2: obscured shadow for moveTo input (parent: 0)
|
|
* 3: stopAllSounds (parent: 0)
|
|
* Inspect fixtures/simple-stack for the full object.
|
|
*/
|
|
|
|
test('top-level block IDs have all changed', t => {
|
|
newBlocks.forEach((block, i) => {
|
|
t.notEqual(block.id, originals[i].id);
|
|
});
|
|
t.end();
|
|
});
|
|
|
|
test('input reference is maintained on parent for attached block', t => {
|
|
t.equal(newBlocks[0].inputs.TO.block, newBlocks[1].id);
|
|
t.end();
|
|
});
|
|
|
|
test('input reference is maintained on parent for obscured shadow', t => {
|
|
t.equal(newBlocks[0].inputs.TO.shadow, newBlocks[2].id);
|
|
t.end();
|
|
});
|
|
|
|
test('parent reference is maintained for attached input', t => {
|
|
t.equal(newBlocks[1].parent, newBlocks[0].id);
|
|
t.end();
|
|
});
|
|
|
|
test('parent reference is maintained for obscured shadow', t => {
|
|
t.equal(newBlocks[2].parent, newBlocks[0].id);
|
|
t.end();
|
|
});
|
|
|
|
test('parent reference is maintained for next block', t => {
|
|
t.equal(newBlocks[3].parent, newBlocks[0].id);
|
|
t.end();
|
|
});
|
|
|
|
test('next reference is maintained for previous block', t => {
|
|
t.equal(newBlocks[0].next, newBlocks[3].id);
|
|
t.end();
|
|
});
|