Merge pull request from thisandagain/testing

Test Suite Adjustments
This commit is contained in:
Shane M. Clements 2014-04-10 14:46:21 -06:00
commit fa42953d58
25 changed files with 1195 additions and 1133 deletions

26
.jscsrc Normal file
View file

@ -0,0 +1,26 @@
{
"requireCurlyBraces": [
"for",
"while",
"do",
"try",
"catch"
],
"requireSpaceAfterKeywords": [
"default"
],
"requireSpacesInFunctionExpression": {
"beforeOpeningCurlyBrace": true
},
"disallowSpacesInFunctionExpression": {
"beforeOpeningRoundBrace": true
},
"disallowEmptyBlocks": true,
"disallowSpaceAfterObjectKeys": true,
"requireCommaBeforeLineBreak": true,
"disallowSpaceBeforePostfixUnaryOperators": ["++", "--"],
"validateIndentation": 4,
"disallowMixedSpacesAndTabs": true,
"disallowTrailingWhitespace": true,
"safeContextKeyword": "self"
}

View file

@ -28,41 +28,18 @@ The tests are written using Karma and there should be a 100% passing rate in ord
The expectation is to add a unit test for any code that you contribute to the project. The expectation is to add a unit test for any code that you contribute to the project.
Install Node (NPM) (https://npmjs.org/) Install Node
--------------------------------------- ---------------------------------------
Brew: To install [Node.js](http://nodejs.org) and [NPM](http://npmjs.org) simply go to [http://nodejs.org](http://nodejs.org/), download the package for your operating system and install. Once installed, navigate to your local scratch directory and run:
```
$ brew install npm
```
Mac Ports: ```bash
``` npm install
$ port install npm
```
In your local scratch directory
```
$ npm install
```
Local copy of jQuery
--------------------
```
$ cd test/lib
$ curl http://code.jquery.com/jquery-1.11.0.min.js > jquery-1.11.0.min.js
``` ```
To Run the tests To Run the tests
---------------- ----------------
```bash
npm test
``` ```
$ ./scripts/test.sh
```
To configure the unit tests
---------------------------
The karam.conf.js file is location in the config directory

View file

@ -37,12 +37,12 @@ var IO = function() {
}; };
IO.prototype.loadProject = function(project_id) { IO.prototype.loadProject = function(project_id) {
var runningIO = this; var self = this;
$.getJSON(this.project_base + project_id + this.project_suffix, function(data) { $.getJSON(this.project_base + project_id + this.project_suffix, function(data) {
runningIO.data = data; self.data = data;
runningIO.makeObjects(); self.makeObjects();
runningIO.loadThreads(); self.loadThreads();
runningIO.loadNotesDrums(); self.loadNotesDrums();
runtime.loadStart(); // Try to run the project. runtime.loadStart(); // Try to run the project.
}); });
}; };
@ -126,8 +126,8 @@ IO.prototype.makeObjects = function() {
$.each(this.data.children, function(index, obj) { $.each(this.data.children, function(index, obj) {
createObj(obj, runtime.stage); // create children of stage - sprites, watchers, and stage's lists createObj(obj, runtime.stage); // create children of stage - sprites, watchers, and stage's lists
}); });
$.each(runtime.sprites.filter(function(sprite){return sprite instanceof Sprite}), function(index, sprite) { // list of sprites $.each(runtime.sprites.filter(function(sprite) {return sprite instanceof Sprite}), function(index, sprite) { // list of sprites
$.each(sprite.lists, function(index, list){ $.each(sprite.lists, function(index, list) {
createObj(list, sprite); // create local lists createObj(list, sprite); // create local lists
}); });
}); });

View file

@ -319,8 +319,11 @@ Interpreter.prototype.lookupPrim = function(op) {
Interpreter.prototype.primNoop = function(b) { console.log(b.op); }; Interpreter.prototype.primNoop = function(b) { console.log(b.op); };
Interpreter.prototype.primWait = function(b) { Interpreter.prototype.primWait = function(b) {
if (interp.activeThread.firstTime) interp.startTimer(interp.numarg(b, 0)); if (interp.activeThread.firstTime) {
else interp.checkTimer(); interp.startTimer(interp.numarg(b, 0));
} else {
interp.checkTimer();
}
}; };
Interpreter.prototype.primRepeat = function(b) { Interpreter.prototype.primRepeat = function(b) {
@ -348,7 +351,9 @@ Interpreter.prototype.broadcast = function(b, waitFlag) {
} }
} }
runtime.allStacksDo(findReceivers); runtime.allStacksDo(findReceivers);
for (pair in receivers) interp.restartThread(receivers[pair][0], receivers[pair][1]); for (pair in receivers) {
interp.restartThread(receivers[pair][0], receivers[pair][1]);
}
if (!waitFlag) return; if (!waitFlag) return;
interp.activeThread.tmpObj = receivers; interp.activeThread.tmpObj = receivers;
interp.activeThread.firstTime = false; interp.activeThread.firstTime = false;

View file

@ -38,13 +38,9 @@ var Reporter = function(data) {
}; };
Reporter.prototype.determineReporterLabel = function() { Reporter.prototype.determineReporterLabel = function() {
if (this.target === 'Stage' && this.cmd === "getVar:") { if (this.target === 'Stage' && this.cmd === "getVar:") return this.param;
return this.param; if (this.target === 'Stage' && this.param === null) return this.cmd;
} else if (this.target === 'Stage' && this.param === null) {
return this.cmd;
} else {
return this.target + ': ' + this.param; return this.target + ': ' + this.param;
}
} }
Reporter.prototype.attach = function(scene) { Reporter.prototype.attach = function(scene) {
@ -164,10 +160,10 @@ List.prototype.attach = function(scene) {
var c = this.containerEl = $('<div style="overflow:hidden;float:left;position:relative">').appendTo(this.el).width(this.width-13).height(this.height-34); var c = this.containerEl = $('<div style="overflow:hidden;float:left;position:relative">').appendTo(this.el).width(this.width-13).height(this.height-34);
var s = this.scrollbar = $('<div class="list-scrollbar-container"><div class="list-scrollbar">').appendTo(this.el); var s = this.scrollbar = $('<div class="list-scrollbar-container"><div class="list-scrollbar">').appendTo(this.el);
var sb = s.children('.list-scrollbar'); var sb = s.children('.list-scrollbar');
sb.mousedown(function(e){ sb.mousedown(function(e) {
if (e.which===1) $(this).data({scrolling:true,startY:e.pageY}); // left button if (e.which===1) $(this).data({scrolling:true,startY:e.pageY}); // left button
}); });
$('body').mousemove(function(e){ $('body').mousemove(function(e) {
if (sb.data('scrolling')) { if (sb.data('scrolling')) {
var offset = parseInt(sb.css('top'))+e.pageY-sb.data('startY'); var offset = parseInt(sb.css('top'))+e.pageY-sb.data('startY');
if (offset < 0) { if (offset < 0) {
@ -179,7 +175,7 @@ List.prototype.attach = function(scene) {
sb.css('top',offset); sb.css('top',offset);
c.scrollTop(c.height()/sb.height()*offset); c.scrollTop(c.height()/sb.height()*offset);
} }
}).mouseup(function(){ }).mouseup(function() {
if ($.hasData(sb[0],'scrolling')) sb.removeData(['scrolling','startY']); if ($.hasData(sb[0],'scrolling')) sb.removeData(['scrolling','startY']);
}); });
// this.el.append('<div class="list-add">+'); // disabled because it doesn't do anything even in the original // this.el.append('<div class="list-add">+'); // disabled because it doesn't do anything even in the original
@ -194,14 +190,14 @@ List.prototype.attach = function(scene) {
this.el.css('display', this.visible ? 'inline-block' : 'none'); this.el.css('display', this.visible ? 'inline-block' : 'none');
}; };
List.prototype.update = function(){ List.prototype.update = function() {
this.contents = findList(runtime.spriteNamed(this.target),this.listName); this.contents = findList(runtime.spriteNamed(this.target),this.listName);
this.el.css('display', this.visible ? 'inline-block' : 'none'); this.el.css('display', this.visible ? 'inline-block' : 'none');
if (!this.visible) return; if (!this.visible) return;
var c = this.containerEl.html(''); // so that it can be used inside the forEach var c = this.containerEl.html(''); // so that it can be used inside the forEach
this.contents.forEach(function(val,i){ this.contents.forEach(function(val,i) {
$('<div style="clear:both">').appendTo(c).append('<div class="list-index">'+(i+1),'<div class="list-item">'+val); $('<div style="clear:both">').appendTo(c).append('<div class="list-index">'+(i+1),'<div class="list-item">'+val);
}); });
c.find('.list-index').width(c.find('.list-index').last().width()); c.find('.list-index').width(c.find('.list-index').last().width());

View file

@ -42,9 +42,9 @@ Runtime.prototype.init = function() {
this.scene = $('#container'); this.scene = $('#container');
window.AudioContext = window.AudioContext || window.webkitAudioContext; window.AudioContext = window.AudioContext || window.webkitAudioContext;
this.audioContext = new AudioContext(); this.audioContext = new AudioContext();
try{ try {
this.audioGain = this.audioContext.createGain(); this.audioGain = this.audioContext.createGain();
}catch(err){ } catch(err) {
this.audioGain = this.audioContext.createGainNode(); this.audioGain = this.audioContext.createGainNode();
} }
this.audioGain.connect(runtime.audioContext.destination); this.audioGain.connect(runtime.audioContext.destination);

View file

@ -173,9 +173,9 @@ Sprite.prototype.attach = function(scene) {
// Load sounds from the server and buffer them // Load sounds from the server and buffer them
Sprite.prototype.loadSounds = function() { Sprite.prototype.loadSounds = function() {
var spr = this; var self = this;
$.each(this.sounds, function(index, sound) { $.each(this.sounds, function(index, sound) {
io.soundRequest(sound, spr); io.soundRequest(sound, self);
}); });
}; };
@ -308,21 +308,27 @@ Sprite.prototype.updateTransform = function() {
// sign to the X scale. // sign to the X scale.
} }
$(this.mesh).css('transform', $(this.mesh).css(
'translatex(' + drawX + 'px) \ 'transform',
translatey(' + drawY + 'px) \ 'translatex(' + drawX + 'px) ' +
rotate(' + this.rotation + 'deg) \ 'translatey(' + drawY + 'px) ' +
scaleX(' + scaleXprepend + (this.scale / resolution) + ') scaleY(' + (this.scale / resolution) + ')'); 'rotate(' + this.rotation + 'deg) ' +
$(this.mesh).css('-moz-transform', 'scaleX(' + scaleXprepend + (this.scale / resolution) + ') scaleY(' + (this.scale / resolution) + ')'
'translatex(' + drawX + 'px) \ );
translatey(' + drawY + 'px) \ $(this.mesh).css(
rotate(' + this.rotation + 'deg) \ '-moz-transform',
scaleX(' + scaleXprepend + this.scale + ') scaleY(' + this.scale / resolution + ')'); 'translatex(' + drawX + 'px) ' +
$(this.mesh).css('-webkit-transform', 'translatey(' + drawY + 'px) ' +
'translatex(' + drawX + 'px) \ 'rotate(' + this.rotation + 'deg) ' +
translatey(' + drawY + 'px) \ 'scaleX(' + scaleXprepend + this.scale + ') scaleY(' + this.scale / resolution + ')'
rotate(' + this.rotation + 'deg) \ );
scaleX(' + scaleXprepend + (this.scale / resolution) + ') scaleY(' + (this.scale / resolution) + ')'); $(this.mesh).css(
'-webkit-transform',
'translatex(' + drawX + 'px) ' +
'translatey(' + drawY + 'px) ' +
'rotate(' + this.rotation + 'deg) ' +
'scaleX(' + scaleXprepend + (this.scale / resolution) + ') scaleY(' + (this.scale / resolution) + ')'
);
$(this.mesh).css('-webkit-transform-origin', rotationCenterX + 'px ' + rotationCenterY + 'px'); $(this.mesh).css('-webkit-transform-origin', rotationCenterX + 'px ' + rotationCenterY + 'px');
$(this.mesh).css('-moz-transform-origin', rotationCenterX + 'px ' + rotationCenterY + 'px'); $(this.mesh).css('-moz-transform-origin', rotationCenterX + 'px ' + rotationCenterY + 'px');
@ -342,9 +348,11 @@ Sprite.prototype.updateTransform = function() {
Sprite.prototype.updateFilters = function() { Sprite.prototype.updateFilters = function() {
$(this.mesh).css('opacity', 1 - this.filters.ghost / 100); $(this.mesh).css('opacity', 1 - this.filters.ghost / 100);
$(this.mesh).css('-webkit-filter', $(this.mesh).css(
'hue-rotate(' + (this.filters.color * 1.8) + 'deg) \ '-webkit-filter',
brightness(' + (this.filters.brightness < 0 ? this.filters.brightness / 100 + 1 : Math.min(2.5, this.filters.brightness * .015 + 1)) + ')'); 'hue-rotate(' + (this.filters.color * 1.8) + 'deg) ' +
'brightness(' + (this.filters.brightness < 0 ? this.filters.brightness / 100 + 1 : Math.min(2.5, this.filters.brightness * .015 + 1)) + ')'
);
}; };
Sprite.prototype.getTalkBubbleXY = function() { Sprite.prototype.getTalkBubbleXY = function() {
@ -416,7 +424,7 @@ Sprite.prototype.hideAsk = function() {
Sprite.prototype.bindDoAskButton = function() { Sprite.prototype.bindDoAskButton = function() {
var self = this; var self = this;
this.askInputButton.on("keypress click", function(e){ this.askInputButton.on("keypress click", function(e) {
var eType = e.type; var eType = e.type;
if (eType === 'click' || (eType === 'keypress' && e.which === 13)) { if (eType === 'click' || (eType === 'keypress' && e.which === 13)) {
var stage = interp.targetStage(); var stage = interp.targetStage();

View file

@ -33,7 +33,7 @@ SensingPrims.prototype.addPrimsTo = function(primTable) {
primTable['getAttribute:of:'] = this.primGetAttribute; primTable['getAttribute:of:'] = this.primGetAttribute;
primTable['timeAndDate'] = function(b){ return runtime.getTimeString(interp.arg(b, 0)); }; primTable['timeAndDate'] = function(b) { return runtime.getTimeString(interp.arg(b, 0)); };
primTable['timestamp'] = this.primTimestamp; primTable['timestamp'] = this.primTimestamp;
}; };

View file

@ -123,9 +123,13 @@ VarListPrims.prototype.primListDeleteLine = function(b) {
var list = findList(interp.targetSprite(), interp.arg(b, 1)); var list = findList(interp.targetSprite(), interp.arg(b, 1));
if (!list) return; if (!list) return;
var line = interp.arg(b, 0); var line = interp.arg(b, 0);
if (line == 'all' || list.length == 0) list.length = 0; if (line == 'all' || list.length == 0) {
else if (line == 'last') list.splice(list.length - 1, 1); list.length = 0;
else if (parseInt(line, 10) - 1 in list) list.splice(parseInt(line, 10) - 1, 1); } else if (line == 'last') {
list.splice(list.length - 1, 1);
} else if (parseInt(line, 10) - 1 in list) {
list.splice(parseInt(line, 10) - 1, 1);
}
}; };
VarListPrims.prototype.primListInsertAt = function(b) { VarListPrims.prototype.primListInsertAt = function(b) {
@ -134,9 +138,13 @@ VarListPrims.prototype.primListInsertAt = function(b) {
var newItem = interp.arg(b, 0); var newItem = interp.arg(b, 0);
var position = interp.arg(b, 1); var position = interp.arg(b, 1);
if (position == 'last') position = list.length; if (position == 'last') {
else if (position == 'random') position = Math.round(Math.random() * list.length); position = list.length;
else position = parseInt(position, 10) - 1; } else if (position == 'random') {
position = Math.round(Math.random() * list.length);
} else {
position = parseInt(position, 10) - 1;
}
if (position > list.length) return; if (position > list.length) return;
list.splice(position, 0, newItem); list.splice(position, 0, newItem);
@ -148,12 +156,15 @@ VarListPrims.prototype.primListSetLine = function(b) {
var newItem = interp.arg(b, 2); var newItem = interp.arg(b, 2);
var position = interp.arg(b, 0); var position = interp.arg(b, 0);
if (position == 'last') position = list.length - 1; if (position == 'last') {
else if (position == 'random') position = Math.floor(Math.random() * list.length); position = list.length - 1;
else position = parseInt(position, 10) - 1; } else if (position == 'random') {
position = Math.floor(Math.random() * list.length);
} else {
position = parseInt(position, 10) - 1;
}
if (position > list.length - 1) return; if (position > list.length - 1) return;
list[position] = newItem; list[position] = newItem;
}; };

View file

@ -107,8 +107,8 @@ NotePlayer.prototype.interpolatedSample = function() {
NotePlayer.prototype.rawSample = function(sampleIndex) { NotePlayer.prototype.rawSample = function(sampleIndex) {
if (sampleIndex >= this.endOffset) { if (sampleIndex >= this.endOffset) {
if (this.isLooped) sampleIndex = this.loopPoint; if (!this.isLooped) return 0;
else return 0; sampleIndex = this.loopPoint;
} }
var byteIndex = 2 * sampleIndex; var byteIndex = 2 * sampleIndex;
var result = (this.soundData[byteIndex + 1] << 8) + this.soundData[byteIndex]; var result = (this.soundData[byteIndex + 1] << 8) + this.soundData[byteIndex];

View file

@ -32,7 +32,8 @@ var SoundBank = function() {};
// The loop points are -1 if the sound is unlooped (e.g. Marimba). // The loop points are -1 if the sound is unlooped (e.g. Marimba).
// The three-element envelop array may be omitted if the instrument has no envelope. // The three-element envelop array may be omitted if the instrument has no envelope.
SoundBank.instruments = [ SoundBank.instruments = [
[[38, 'AcousticPiano_As3', 58, 10266, 17053, [0, 100, 22]], [
[38, 'AcousticPiano_As3', 58, 10266, 17053, [0, 100, 22]],
[44, 'AcousticPiano_C4', 60, 13968, 18975, [0, 100, 20]], [44, 'AcousticPiano_C4', 60, 13968, 18975, [0, 100, 20]],
[51, 'AcousticPiano_G4', 67, 12200, 12370, [0, 80, 18]], [51, 'AcousticPiano_G4', 67, 12200, 12370, [0, 80, 18]],
[62, 'AcousticPiano_C6', 84, 13042, 13276, [0, 80, 16]], [62, 'AcousticPiano_C6', 84, 13042, 13276, [0, 80, 16]],
@ -41,105 +42,126 @@ SoundBank.instruments = [
[85, 'AcousticPiano_Ds6', 87, 12368, 12869, [0, 0, 8]], [85, 'AcousticPiano_Ds6', 87, 12368, 12869, [0, 0, 8]],
[90, 'AcousticPiano_Ds6', 87, 12368, 12869, [0, 0, 6]], [90, 'AcousticPiano_Ds6', 87, 12368, 12869, [0, 0, 6]],
[96, 'AcousticPiano_D7', 98, 7454, 7606, [0, 0, 3]], [96, 'AcousticPiano_D7', 98, 7454, 7606, [0, 0, 3]],
[128, 'AcousticPiano_D7', 98, 7454, 7606, [0, 0, 2]]], [128, 'AcousticPiano_D7', 98, 7454, 7606, [0, 0, 2]]
],
[[48, 'ElectricPiano_C2', 36, 15338, 17360, [0, 80, 10]], [
[48, 'ElectricPiano_C2', 36, 15338, 17360, [0, 80, 10]],
[74, 'ElectricPiano_C4', 60, 11426, 12016, [0, 40, 8]], [74, 'ElectricPiano_C4', 60, 11426, 12016, [0, 40, 8]],
[128, 'ElectricPiano_C4', 60, 11426, 12016, [0, 0, 6]]], [128, 'ElectricPiano_C4', 60, 11426, 12016, [0, 0, 6]]
],
[[128, 'Organ_G2', 43, 1306, 3330]], [
[128, 'Organ_G2', 43, 1306, 3330]
[[40, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 15]], ],
[
[40, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 15]],
[56, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 13.5]], [56, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 13.5]],
[60, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 12]], [60, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 12]],
[67, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 8.5]], [67, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 8.5]],
[72, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 7]], [72, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 7]],
[83, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 5.5]], [83, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 5.5]],
[128, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 4.5]]], [128, 'AcousticGuitar_F3', 53, 36665, 36791, [0, 0, 4.5]]
],
[[40, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 15]], [
[40, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 15]],
[56, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 13.5]], [56, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 13.5]],
[60, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 12]], [60, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 12]],
[67, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 8.5]], [67, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 8.5]],
[72, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 7]], [72, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 7]],
[83, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 5.5]], [83, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 5.5]],
[128, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 4.5]]], [128, 'ElectricGuitar_F3', 53, 34692, 34945, [0, 0, 4.5]]
],
[[34, 'ElectricBass_G1', 31, 41912, 42363, [0, 0, 17]], [
[34, 'ElectricBass_G1', 31, 41912, 42363, [0, 0, 17]],
[48, 'ElectricBass_G1', 31, 41912, 42363, [0, 0, 14]], [48, 'ElectricBass_G1', 31, 41912, 42363, [0, 0, 14]],
[64, 'ElectricBass_G1', 31, 41912, 42363, [0, 0, 12]], [64, 'ElectricBass_G1', 31, 41912, 42363, [0, 0, 12]],
[128, 'ElectricBass_G1', 31, 41912, 42363, [0, 0, 10]]], [128, 'ElectricBass_G1', 31, 41912, 42363, [0, 0, 10]]
],
[[38, 'Pizz_G2', 43, 8554, 8782, [0, 0, 5]], [
[38, 'Pizz_G2', 43, 8554, 8782, [0, 0, 5]],
[45, 'Pizz_G2', 43, 8554, 8782, [0, 12, 4]], [45, 'Pizz_G2', 43, 8554, 8782, [0, 12, 4]],
[56, 'Pizz_A3', 57, 11460, 11659, [0, 0, 4]], [56, 'Pizz_A3', 57, 11460, 11659, [0, 0, 4]],
[64, 'Pizz_A3', 57, 11460, 11659, [0, 0, 3.2]], [64, 'Pizz_A3', 57, 11460, 11659, [0, 0, 3.2]],
[72, 'Pizz_E4', 64, 17525, 17592, [0, 0, 2.8]], [72, 'Pizz_E4', 64, 17525, 17592, [0, 0, 2.8]],
[80, 'Pizz_E4', 64, 17525, 17592, [0, 0, 2.2]], [80, 'Pizz_E4', 64, 17525, 17592, [0, 0, 2.2]],
[128, 'Pizz_E4', 64, 17525, 17592, [0, 0, 1.5]]], [128, 'Pizz_E4', 64, 17525, 17592, [0, 0, 1.5]]
],
[[41, 'Cello_C2', 36, 8548, 8885], [
[41, 'Cello_C2', 36, 8548, 8885],
[52, 'Cello_As2', 46, 7465, 7845], [52, 'Cello_As2', 46, 7465, 7845],
[62, 'Violin_D4', 62, 10608, 11360], [62, 'Violin_D4', 62, 10608, 11360],
[75, 'Violin_A4', 69, 3111, 3314, [70, 0, 0]], [75, 'Violin_A4', 69, 3111, 3314, [70, 0, 0]],
[128, 'Violin_E5', 76, 2383, 2484]], [128, 'Violin_E5', 76, 2383, 2484]
],
[[30, 'BassTrombone_A2_3', 45, 1357, 2360], [
[30, 'BassTrombone_A2_3', 45, 1357, 2360],
[40, 'BassTrombone_A2_2', 45, 1893, 2896], [40, 'BassTrombone_A2_2', 45, 1893, 2896],
[55, 'Trombone_B3', 59, 2646, 3897], [55, 'Trombone_B3', 59, 2646, 3897],
[88, 'Trombone_B3', 59, 2646, 3897, [50, 0, 0]], [88, 'Trombone_B3', 59, 2646, 3897, [50, 0, 0]],
[128, 'Trumpet_E5', 76, 2884, 3152]], [128, 'Trumpet_E5', 76, 2884, 3152]
],
[[128, 'Clarinet_C4', 60, 14540, 15468]], [
[128, 'Clarinet_C4', 60, 14540, 15468]
[[40, 'TenorSax_C3', 48, 8939, 10794], ],
[
[40, 'TenorSax_C3', 48, 8939, 10794],
[50, 'TenorSax_C3', 48, 8939, 10794, [20, 0, 0]], [50, 'TenorSax_C3', 48, 8939, 10794, [20, 0, 0]],
[59, 'TenorSax_C3', 48, 8939, 10794, [40, 0, 0]], [59, 'TenorSax_C3', 48, 8939, 10794, [40, 0, 0]],
[67, 'AltoSax_A3', 57, 8546, 9049], [67, 'AltoSax_A3', 57, 8546, 9049],
[75, 'AltoSax_A3', 57, 8546, 9049, [20, 0, 0]], [75, 'AltoSax_A3', 57, 8546, 9049, [20, 0, 0]],
[80, 'AltoSax_A3', 57, 8546, 9049, [20, 0, 0]], [80, 'AltoSax_A3', 57, 8546, 9049, [20, 0, 0]],
[128, 'AltoSax_C6', 84, 1258, 1848]], [128, 'AltoSax_C6', 84, 1258, 1848]
],
[[61, 'Flute_B5_2', 83, 1859, 2259], [
[128, 'Flute_B5_1', 83, 2418, 2818]], [61, 'Flute_B5_2', 83, 1859, 2259],
[128, 'Flute_B5_1', 83, 2418, 2818]
[[128, 'WoodenFlute_C5', 72, 11426, 15724]], ],
[
[[57, 'Bassoon_C3', 48, 2428, 4284], [128, 'WoodenFlute_C5', 72, 11426, 15724]
],
[
[57, 'Bassoon_C3', 48, 2428, 4284],
[67, 'Bassoon_C3', 48, 2428, 4284, [40, 0, 0]], [67, 'Bassoon_C3', 48, 2428, 4284, [40, 0, 0]],
[76, 'Bassoon_C3', 48, 2428, 4284, [80, 0, 0]], [76, 'Bassoon_C3', 48, 2428, 4284, [80, 0, 0]],
[84, 'EnglishHorn_F3', 53, 7538, 8930, [40, 0, 0]], [84, 'EnglishHorn_F3', 53, 7538, 8930, [40, 0, 0]],
[128, 'EnglishHorn_D4', 62, 4857, 5231]], [128, 'EnglishHorn_D4', 62, 4857, 5231]
],
[[39, 'Choir_F3', 53, 14007, 41281], [
[39, 'Choir_F3', 53, 14007, 41281],
[50, 'Choir_F3', 53, 14007, 41281, [40, 0, 0]], [50, 'Choir_F3', 53, 14007, 41281, [40, 0, 0]],
[61, 'Choir_F3', 53, 14007, 41281, [60, 0, 0]], [61, 'Choir_F3', 53, 14007, 41281, [60, 0, 0]],
[72, 'Choir_F4', 65, 16351, 46436], [72, 'Choir_F4', 65, 16351, 46436],
[128, 'Choir_F5', 77, 18440, 45391]], [128, 'Choir_F5', 77, 18440, 45391]
],
[[38, 'Vibraphone_C3', 48, 6202, 6370, [0, 100, 8]], [
[38, 'Vibraphone_C3', 48, 6202, 6370, [0, 100, 8]],
[48, 'Vibraphone_C3', 48, 6202, 6370, [0, 100, 7.5]], [48, 'Vibraphone_C3', 48, 6202, 6370, [0, 100, 7.5]],
[59, 'Vibraphone_C3', 48, 6202, 6370, [0, 60, 7]], [59, 'Vibraphone_C3', 48, 6202, 6370, [0, 60, 7]],
[70, 'Vibraphone_C3', 48, 6202, 6370, [0, 40, 6]], [70, 'Vibraphone_C3', 48, 6202, 6370, [0, 40, 6]],
[78, 'Vibraphone_C3', 48, 6202, 6370, [0, 20, 5]], [78, 'Vibraphone_C3', 48, 6202, 6370, [0, 20, 5]],
[86, 'Vibraphone_C3', 48, 6202, 6370, [0, 0, 4]], [86, 'Vibraphone_C3', 48, 6202, 6370, [0, 0, 4]],
[128, 'Vibraphone_C3', 48, 6202, 6370, [0, 0, 3]]], [128, 'Vibraphone_C3', 48, 6202, 6370, [0, 0, 3]]
],
[[128, 'MusicBox_C4', 60, 14278, 14700, [0, 0, 2]]], [
[128, 'MusicBox_C4', 60, 14278, 14700, [0, 0, 2]]
[[128, 'SteelDrum_D5', 74.4, -1, -1, [0, 0, 2]]], ],
[
[[128, 'Marimba_C4', 60, -1, -1]], [128, 'SteelDrum_D5', 74.4, -1, -1, [0, 0, 2]]
],
[[80, 'SynthLead_C4', 60, 135, 1400], [
[128, 'SynthLead_C6', 84, 124, 356]], [128, 'Marimba_C4', 60, -1, -1]
],
[[38, 'SynthPad_A3', 57, 4212, 88017, [50, 0, 0]], [
[80, 'SynthLead_C4', 60, 135, 1400],
[128, 'SynthLead_C6', 84, 124, 356]
],
[
[38, 'SynthPad_A3', 57, 4212, 88017, [50, 0, 0]],
[50, 'SynthPad_A3', 57, 4212, 88017, [80, 0, 0]], [50, 'SynthPad_A3', 57, 4212, 88017, [80, 0, 0]],
[62, 'SynthPad_A3', 57, 4212, 88017, [110, 0, 0]], [62, 'SynthPad_A3', 57, 4212, 88017, [110, 0, 0]],
[74, 'SynthPad_A3', 57, 4212, 88017, [150, 0, 0]], [74, 'SynthPad_A3', 57, 4212, 88017, [150, 0, 0]],
[86, 'SynthPad_A3', 57, 4212, 88017, [200, 0, 0]], [86, 'SynthPad_A3', 57, 4212, 88017, [200, 0, 0]],
[128, 'SynthPad_C6', 84, 2575, 9202]], [128, 'SynthPad_C6', 84, 2575, 9202]
]
]; ];
// ----------------------------- // -----------------------------

20
makefile Normal file
View file

@ -0,0 +1,20 @@
JSCS_PATH = ./node_modules/.bin/jscs
KARMA_PATH = ./node_modules/.bin/karma
KARMA_CONFIG = ./test/fixtures/karma.conf.js
# Performs code governance (lint + style) test
lint:
@$(JSCS_PATH) ./js/*
@$(JSCS_PATH) ./test/unit/*
# Performs unit tests
unit:
@$(KARMA_PATH) start $(KARMA_CONFIG) $*
# Run all test targets
test:
@make lint
@make unit
# Ignore directory structure
.PHONY: lint unit test

View file

@ -2,10 +2,19 @@
"name": "scratch-html5", "name": "scratch-html5",
"description": "HTML 5 based Scratch project player", "description": "HTML 5 based Scratch project player",
"repository": "https://github.com/LLK/scratch-html5", "repository": "https://github.com/LLK/scratch-html5",
"scripts": {
"postinstall": "curl http://code.jquery.com/jquery-1.11.0.min.js > ./test/lib/jquery-1.11.0.min.js",
"test": "make test"
},
"engines": {
"node": ">=0.10"
},
"dependencies": {},
"devDependencies": { "devDependencies": {
"karma" : "~0.10", "jasmine-jquery": "~1.3.3",
"jasmine-jquery" : "1.3.3", "jscs": "~1.3.0",
"karma-html2js-preprocessor" : "~0.1.0", "karma": "~0.10",
"underscore" : "~1.6.0" "karma-html2js-preprocessor": "~0.1.0",
"underscore": "~1.6.0"
} }
} }

View file

@ -1,9 +0,0 @@
#!/bin/bash
BASE_DIR=`dirname $0`
echo ""
echo "Starting Karma Server (http://karma-runner.github.io)"
echo "-------------------------------------------------------------------"
$BASE_DIR/../node_modules/karma/bin/karma start $BASE_DIR/../config/karma.conf.js $*

View file

@ -1,6 +1,6 @@
module.exports = function(config){ module.exports = function(config){
config.set({ config.set({
basePath : '../', basePath : '../../',
files : [ files : [
'test/artifacts/**/*.js', 'test/artifacts/**/*.js',

View file

@ -2,7 +2,7 @@
/* jasmine specs for IO.js go here */ /* jasmine specs for IO.js go here */
describe('IO', function(){ describe('IO', function() {
var io; var io;
beforeEach(function() { beforeEach(function() {

View file

@ -7,7 +7,7 @@ describe('LooksPrims', function() {
targetSpriteMock = targetMock(); targetSpriteMock = targetMock();
}); });
describe('showBubble for say', function(){ describe('showBubble for say', function() {
var sayBlock; var sayBlock;
beforeEach(function() { beforeEach(function() {
sayBlock = {'args': ['what to say']}; sayBlock = {'args': ['what to say']};
@ -21,7 +21,7 @@ describe('LooksPrims', function() {
}); });
}); });
describe('showBubble for think', function(){ describe('showBubble for think', function() {
var thinkBlock; var thinkBlock;
beforeEach(function() { beforeEach(function() {
thinkBlock = {'args': ['what to think']}; thinkBlock = {'args': ['what to think']};
@ -35,7 +35,7 @@ describe('LooksPrims', function() {
}); });
}); });
describe('showBubble for ask', function(){ describe('showBubble for ask', function() {
var askBlock; var askBlock;
beforeEach(function() { beforeEach(function() {
askBlock = {'args': ['what to ask']}; askBlock = {'args': ['what to ask']};

View file

@ -10,7 +10,7 @@ describe('Scratch', function() {
scratch = Scratch; scratch = Scratch;
}); });
describe('Scratch - Load Project', function(){ describe('Scratch - Load Project', function() {
beforeEach(function() { beforeEach(function() {
scratch(project_id); scratch(project_id);
}); });
@ -28,7 +28,7 @@ describe('Scratch', function() {
}); });
}); });
describe('Scratch - Click Green Flag', function(){ describe('Scratch - Click Green Flag', function() {
beforeEach(function() { beforeEach(function() {
setFixtures('<button id=trigger-green-flag tabindex=2></button><div id="overlay"></div>'); setFixtures('<button id=trigger-green-flag tabindex=2></button><div id="overlay"></div>');
scratch(project_id); scratch(project_id);
@ -51,7 +51,7 @@ describe('Scratch', function() {
}); });
}); });
describe('Scratch - Click Stop', function(){ describe('Scratch - Click Stop', function() {
beforeEach(function() { beforeEach(function() {
setFixtures('<button id=trigger-stop tabindex=3></button>'); setFixtures('<button id=trigger-stop tabindex=3></button>');
scratch(project_id); scratch(project_id);

View file

@ -7,16 +7,16 @@ describe('SensingPrims', function() {
realDate = Date; realDate = Date;
}); });
afterEach(function () { afterEach(function() {
Date = realDate; Date = realDate;
}); });
describe('primTimestamp', function(){ describe('primTimestamp', function() {
beforeEach(function() { beforeEach(function() {
/* MonkeyPatching the built-in Javascript Date */ /* MonkeyPatching the built-in Javascript Date */
var epochDate = new Date(2000, 0, 1); var epochDate = new Date(2000, 0, 1);
var nowDate = new Date(2014, 5, 16); var nowDate = new Date(2014, 5, 16);
Date = function () { Date = function() {
return (arguments.length ? epochDate : nowDate); return (arguments.length ? epochDate : nowDate);
}; };
}); });
@ -26,60 +26,60 @@ describe('SensingPrims', function() {
}); });
}); });
describe('primTimeDate', function(){ describe('primTimeDate', function() {
beforeEach(function() { beforeEach(function() {
/* MonkeyPatching the built-in Javascript Date */ /* MonkeyPatching the built-in Javascript Date */
Date = function () { Date = function() {
return { return {
'getFullYear' : function() { return 2014;}, 'getFullYear': function() { return 2014;},
'getMonth' : function() { return 4;}, 'getMonth': function() { return 4;},
'getDate' : function() { return 16;}, 'getDate': function() { return 16;},
'getDay' : function() { return 4;}, 'getDay': function() { return 4;},
'getHours' : function() { return 9;}, 'getHours': function() { return 9;},
'getMinutes' : function() { return 18;}, 'getMinutes': function() { return 18;},
'getSeconds' : function() { return 36;}, 'getSeconds': function() { return 36;},
'getTime' : function() {} 'getTime': function() {}
}; };
}; };
}); });
it('should return the year', function() { it('should return the year', function() {
var block = {'args' : ['year']}; var block = {'args': ['year']};
expect(sensingPrims.prototype.primTimeDate(block)).toEqual(2014); expect(sensingPrims.prototype.primTimeDate(block)).toEqual(2014);
}); });
it('should return the month of the year', function() { it('should return the month of the year', function() {
var block = {'args' : ['month']}; var block = {'args': ['month']};
expect(sensingPrims.prototype.primTimeDate(block)).toEqual(5); expect(sensingPrims.prototype.primTimeDate(block)).toEqual(5);
}); });
it('should return the day of the week', function() { it('should return the day of the week', function() {
var block = {'args' : ['day of week']}; var block = {'args': ['day of week']};
expect(sensingPrims.prototype.primTimeDate(block)).toEqual(5); expect(sensingPrims.prototype.primTimeDate(block)).toEqual(5);
}); });
it('should return the hour of the day', function() { it('should return the hour of the day', function() {
var block = {'args' : ['hour']}; var block = {'args': ['hour']};
expect(sensingPrims.prototype.primTimeDate(block)).toEqual(9); expect(sensingPrims.prototype.primTimeDate(block)).toEqual(9);
}); });
it('should return the minute of the hour', function() { it('should return the minute of the hour', function() {
var block = {'args' : ['minute']}; var block = {'args': ['minute']};
expect(sensingPrims.prototype.primTimeDate(block)).toEqual(18); expect(sensingPrims.prototype.primTimeDate(block)).toEqual(18);
}); });
it('should return the second of the minute', function() { it('should return the second of the minute', function() {
var block = {'args' : ['second']}; var block = {'args': ['second']};
expect(sensingPrims.prototype.primTimeDate(block)).toEqual(36); expect(sensingPrims.prototype.primTimeDate(block)).toEqual(36);
}); });
it('should return the 0 on year', function() { it('should return the 0 on year', function() {
var block = {'args' : ['anythingElse']}; var block = {'args': ['anythingElse']};
expect(sensingPrims.prototype.primTimeDate(block)).toEqual(0); expect(sensingPrims.prototype.primTimeDate(block)).toEqual(0);
}); });
}); });
describe('primAnswer', function(){ describe('primAnswer', function() {
beforeEach(function() { beforeEach(function() {
interp = interpreterMock({'targetSprite': new targetMock()}); interp = interpreterMock({'targetSprite': new targetMock()});
}); });
@ -89,13 +89,12 @@ describe('SensingPrims', function() {
}); });
}); });
describe('primDoAsk', function(){ describe('primDoAsk', function() {
var askBlock, targetSpriteMock; var askBlock, targetSpriteMock;
beforeEach(function() { beforeEach(function() {
targetSpriteMock = targetMock(); targetSpriteMock = targetMock();
askBlock = {'args': 'what to ask'}; askBlock = {'args': 'what to ask'};
interp = interpreterMock({'targetSprite': targetSpriteMock}, {'arg': askBlock}); interp = interpreterMock({'targetSprite': targetSpriteMock}, {'arg': askBlock});
}); });
it('should call the showBubble method on the targetedSprite', function() { it('should call the showBubble method on the targetedSprite', function() {
@ -107,6 +106,4 @@ describe('SensingPrims', function() {
expect(interp.activeThread.paused).toBe(true); expect(interp.activeThread.paused).toBe(true);
}); });
}); });
}); });

View file

@ -75,7 +75,7 @@ describe('Sprite', function() {
spriteProto.talkBubble.append(spriteProto.talkBubbleStyler); spriteProto.talkBubble.append(spriteProto.talkBubbleStyler);
}); });
describe('Say', function(){ describe('Say', function() {
it('should call the showBubble method on the Sprite', function() { it('should call the showBubble method on the Sprite', function() {
var text = "What to say"; var text = "What to say";
spyOn(spriteProto, "getTalkBubbleXY").andReturn([50,50]);; spyOn(spriteProto, "getTalkBubbleXY").andReturn([50,50]);;
@ -87,7 +87,7 @@ describe('Sprite', function() {
}); });
}); });
describe('Think', function(){ describe('Think', function() {
it('should call the showBubble method on the Sprite', function() { it('should call the showBubble method on the Sprite', function() {
var text = "What to think"; var text = "What to think";
spyOn(spriteProto, "getTalkBubbleXY").andReturn([50,50]);; spyOn(spriteProto, "getTalkBubbleXY").andReturn([50,50]);;
@ -99,7 +99,7 @@ describe('Sprite', function() {
}); });
}); });
describe('Ask', function(){ describe('Ask', function() {
it('should call the showBubble method on the Sprite', function() { it('should call the showBubble method on the Sprite', function() {
var text = "What to Ask"; var text = "What to Ask";
spyOn(spriteProto, "getTalkBubbleXY").andReturn([50,50]);; spyOn(spriteProto, "getTalkBubbleXY").andReturn([50,50]);;
@ -111,7 +111,7 @@ describe('Sprite', function() {
}); });
}); });
describe('Any Bubble with visible false', function(){ describe('Any Bubble with visible false', function() {
it('should call the showBubble method on the Sprite and not display it', function() { it('should call the showBubble method on the Sprite and not display it', function() {
spriteProto.visible = false; spriteProto.visible = false;
var text = "What to Ask"; var text = "What to Ask";