Tone.js/test/tests/Signal.js

204 lines
5.7 KiB
JavaScript
Raw Normal View History

2014-06-18 19:42:17 +00:00
define(["chai", "Tone/component/Recorder", "Tone/signal/Signal", "Tone/signal/Add", "Tone/signal/Multiply",
2014-06-18 05:37:01 +00:00
"Tone/signal/Scale", "Tone/source/Oscillator", "Tone/signal/Merge", "Tone/signal/Split"],
function(chai, Recorder, Signal, Add, Multiply, Scale, Oscillator, Merge, Split){
var expect = chai.expect;
//SIGNAL
describe("Tone.Signal", function(){
this.timeout(300);
it("outputs correct value", function(done){
var signal = new Signal(2);
2014-06-18 19:42:17 +00:00
var recorder = new Recorder();
signal.connect(recorder);
recorder.record(0.05);
2014-06-18 05:37:01 +00:00
setTimeout(function(){
2014-06-18 19:42:17 +00:00
var buffer = recorder.getFloat32Array()[0];
for (var i = 0; i < buffer.length; i++){
expect(buffer[i]).to.equal(2);
}
done();
2014-06-18 05:37:01 +00:00
}, 100);
});
it("can change value with sample accurate timing", function(done){
var signal = new Signal(0);
2014-06-18 19:42:17 +00:00
var recorder = new Recorder(1);
signal.connect(recorder);
var waitTime = 0.03;
recorder.record(0.05);
2014-06-18 05:37:01 +00:00
signal.setValueAtTime(1, "+"+waitTime);//ramp after 50ms
setTimeout(function(){
2014-06-18 19:42:17 +00:00
var buffer = recorder.getFloat32Array()[0];
for (var i = 0; i < buffer.length; i++){
if (buffer[i] === 1){
expect(signal.samplesToSeconds(i)).is.closeTo(waitTime, 0.01);
done();
break;
2014-06-18 05:37:01 +00:00
}
2014-06-18 19:42:17 +00:00
}
2014-06-18 05:37:01 +00:00
}, 100);
});
it("can sync to another signal", function(done){
var signal0 = new Signal(1);
var signal1 = new Signal(2);
//sync signal1 to signal0
signal1.sync(signal0);
//change signal0 and signal1 should also change
signal0.setValue(2);
2014-06-18 19:42:17 +00:00
var recorder = new Recorder();
signal1.connect(recorder);
recorder.record(0.05);
2014-06-18 05:37:01 +00:00
setTimeout(function(){
2014-06-18 19:42:17 +00:00
var buffer = recorder.getFloat32Array()[0];
for (var i = 0; i < buffer.length; i++){
expect(buffer[i]).to.equal(4);
}
done();
2014-06-18 05:37:01 +00:00
}, 100);
});
});
//ADD
describe("Tone.Add", function(){
this.timeout(300);
it("correctly sums a signal and a number", function(done){
var signal = new Signal(0);
var adder = new Add(3);
signal.connect(adder);
2014-06-18 19:42:17 +00:00
var recorder = new Recorder();
adder.connect(recorder);
recorder.record(0.05);
2014-06-18 05:37:01 +00:00
setTimeout(function(){
2014-06-18 19:42:17 +00:00
var buffer = recorder.getFloat32Array()[0];
//get the left buffer and check that all values are === 1
for (var i = 0; i < buffer.length; i++){
expect(buffer[i]).to.equal(3);
}
done();
2014-06-18 05:37:01 +00:00
}, 100);
});
it("can handle negative values", function(done){
var signal = new Signal(10);
var adder = new Add(-1);
signal.connect(adder);
2014-06-18 19:42:17 +00:00
var recorder = new Recorder();
adder.connect(recorder);
recorder.record(0.05);
2014-06-18 05:37:01 +00:00
setTimeout(function(){
2014-06-18 19:42:17 +00:00
var buffer = recorder.getFloat32Array()[0];
//get the left buffer and check that all values are === 1
for (var i = 0; i < buffer.length; i++){
expect(buffer[i]).to.equal(9);
}
done();
2014-06-18 05:37:01 +00:00
}, 100);
});
});
//MULTIPLY
describe("Tone.Multiply", function(){
this.timeout(300);
it("correctly multiplys a signal and a scalar", function(done){
var signal = new Signal(2);
var mult = new Multiply(10);
signal.connect(mult);
2014-06-18 19:42:17 +00:00
var recorder = new Recorder();
mult.connect(recorder);
recorder.record(0.05);
2014-06-18 05:37:01 +00:00
setTimeout(function(){
2014-06-18 19:42:17 +00:00
var buffer = recorder.getFloat32Array()[0];
//get the left buffer and check that all values are === 1
for (var i = 0; i < buffer.length; i++){
expect(buffer[i]).to.equal(20);
}
done();
2014-06-18 05:37:01 +00:00
}, 100);
});
});
//SCALE
describe("Tone.Scale", function(){
this.timeout(300);
it("scales an input range to an output range", function(done){
//make an oscillator to drive the signal
var osc = new Oscillator(1000);
osc.start();
var scale = new Scale(-1, 1, 10, 20);
osc.connect(scale);
2014-06-18 19:42:17 +00:00
var recorder = new Recorder();
scale.connect(recorder);
recorder.record(0.05);
2014-06-18 05:37:01 +00:00
setTimeout(function(){
2014-06-18 19:42:17 +00:00
var buffer = recorder.getFloat32Array()[0];
//get the left buffer and check that all values are === 1
for (var i = 0; i < buffer.length; i++){
expect(buffer[i]).to.be.within(10, 20);
}
done();
2014-06-18 05:37:01 +00:00
}, 100);
});
});
2014-06-18 19:42:17 +00:00
//MERGE
2014-06-18 05:37:01 +00:00
describe("Tone.Merge", function(){
this.timeout(300);
it("merge two signal into one stereo signal", function(done){
//make an oscillator to drive the signal
var sigL = new Signal(1);
var sigR = new Signal(2);
var merger = new Merge();
sigL.connect(merger.left);
sigR.connect(merger.right);
2014-06-18 19:42:17 +00:00
var recorder = new Recorder(2);
merger.connect(recorder);
recorder.record(0.05);
2014-06-18 05:37:01 +00:00
setTimeout(function(){
2014-06-18 19:42:17 +00:00
var buffers = recorder.getFloat32Array();
var lBuffer = buffers[0];
var rBuffer = buffers[1];
//get the left buffer and check that all values are === 1
for (var i = 0; i < lBuffer.length; i++){
expect(lBuffer[i]).to.equal(1);
expect(rBuffer[i]).to.equal(2);
}
done();
2014-06-18 05:37:01 +00:00
}, 100);
});
});
//SCALE
describe("Tone.Split", function(){
this.timeout(300);
it("merges two signal into one stereo signal and then split them back into two signals", function(done){
//make an oscillator to drive the signal
var sigL = new Signal(1);
var sigR = new Signal(2);
var merger = new Merge();
var split = new Split();
sigL.connect(merger.left);
sigR.connect(merger.right);
merger.connect(split);
2014-06-18 19:42:17 +00:00
var recorderL = new Recorder();
var recorderR = new Recorder();
split.left.connect(recorderL);
split.right.connect(recorderR);
recorderL.record(0.05);
recorderR.record(0.05);
2014-06-18 05:37:01 +00:00
setTimeout(function(){
//test the left side
2014-06-18 19:42:17 +00:00
var lBuffer = recorderL.getFloat32Array()[0];
for (var i = 0; i < lBuffer.length; i++){
expect(lBuffer[i]).to.equal(1);
}
2014-06-18 05:37:01 +00:00
//test the right side
2014-06-18 19:42:17 +00:00
var rBuffer = recorderR.getFloat32Array()[0];
for (var j = 0; j < rBuffer.length; j++){
expect(rBuffer[j]).to.equal(2);
}
done();
2014-06-18 05:37:01 +00:00
}, 100);
});
});
});