2018-05-18 16:07:20 +00:00
|
|
|
define(["helper/Offline", "helper/Basic", "helper/Test", "Tone/signal/Signal",
|
2018-02-04 18:05:06 +00:00
|
|
|
"Tone/type/Type", "Tone/core/Transport", "helper/ConstantOutput", "Tone/core/Gain"],
|
2018-05-18 16:07:20 +00:00
|
|
|
function(Offline, Basic, Test, Signal, Tone, Transport, ConstantOutput, Gain){
|
2015-08-24 21:29:19 +00:00
|
|
|
|
|
|
|
describe("Signal", function(){
|
|
|
|
|
|
|
|
Basic(Signal);
|
|
|
|
|
|
|
|
context("Signal Rate Value", function(){
|
|
|
|
|
|
|
|
it("handles input and output connections", function(){
|
|
|
|
var signal = new Signal();
|
|
|
|
Test.connect(signal);
|
|
|
|
signal.connect(Test);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can be created with an options object", function(){
|
|
|
|
var signal = new Signal({
|
|
|
|
"value" : 0.2,
|
|
|
|
"units" : Tone.Type.Positive
|
|
|
|
});
|
|
|
|
expect(signal.value).to.be.closeTo(0.2, 0.001);
|
|
|
|
expect(signal.units).to.equal(Tone.Type.Positive);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can start with a value initially", function(){
|
|
|
|
var signal = new Signal(2);
|
|
|
|
expect(signal.value).to.equal(2);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can set a value", function(){
|
|
|
|
var signal = new Signal(0);
|
|
|
|
signal.value = 10;
|
|
|
|
expect(signal.value).to.equal(10);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
2017-02-20 21:40:41 +00:00
|
|
|
it("takes on another signal's value when connected", function(){
|
|
|
|
return ConstantOutput(function(){
|
|
|
|
var sigA = new Signal(0).toMaster();
|
|
|
|
new Signal(3).connect(sigA);
|
|
|
|
}, 3);
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
2018-02-04 18:05:06 +00:00
|
|
|
|
|
|
|
it("takes the first signals value when many values are chained", function(){
|
|
|
|
return ConstantOutput(function(){
|
|
|
|
var sigA = new Signal(3).toMaster();
|
|
|
|
var sigB = new Signal(1).connect(sigA);
|
|
|
|
var sigC = new Signal(2).connect(sigB);
|
|
|
|
}, 2);
|
|
|
|
});
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
context("Scheduling", function(){
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can be scheduled to set a value in the future", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
2015-08-24 21:29:19 +00:00
|
|
|
sig.setValueAtTime(2, 0.2);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 0.3).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time < 0.19){
|
|
|
|
expect(sample).to.be.closeTo(0, 0.001);
|
|
|
|
} else if (time > 0.2){
|
|
|
|
expect(sample).to.be.closeTo(2, 0.001);
|
|
|
|
}
|
|
|
|
});
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can linear ramp from the current value to another value in the future", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
2015-08-24 21:29:19 +00:00
|
|
|
sig.setValueAtTime(0, 0);
|
|
|
|
sig.linearRampToValueAtTime(1, 1);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 1).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
expect(sample).to.be.closeTo(time, 0.001);
|
|
|
|
});
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can schedule an exponential ramp", function(){
|
2015-08-24 21:29:19 +00:00
|
|
|
var sig = new Signal(1);
|
2017-09-15 21:50:12 +00:00
|
|
|
sig.exponentialRampToValueAtTime(3, "+1");
|
2015-08-24 21:29:19 +00:00
|
|
|
sig.dispose();
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can approach a target value", function(){
|
2015-08-24 21:29:19 +00:00
|
|
|
var sig = new Signal(1);
|
2017-09-15 21:50:12 +00:00
|
|
|
sig.setTargetAtTime(0.2, "+1", 2);
|
2015-08-24 21:29:19 +00:00
|
|
|
sig.dispose();
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set a ramp point at the current value", function(){
|
2015-08-24 21:29:19 +00:00
|
|
|
var sig = new Signal(1);
|
|
|
|
sig.setRampPoint();
|
|
|
|
sig.dispose();
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can schedule multiple automations", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
2015-08-24 21:29:19 +00:00
|
|
|
sig.setValueAtTime(0, 0);
|
|
|
|
sig.linearRampToValueAtTime(0.5, 0.5);
|
|
|
|
sig.linearRampToValueAtTime(0, 1);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 1).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time < 0.5){
|
|
|
|
expect(sample).to.be.closeTo(time, 0.01);
|
|
|
|
} else {
|
|
|
|
expect(sample).to.be.closeTo(1 - time, 0.01);
|
|
|
|
}
|
|
|
|
});
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-02-04 18:05:06 +00:00
|
|
|
it("can schedule multiple automations from a connected signal", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var output = new Signal(1).toMaster();
|
|
|
|
var sig = new Signal(0).connect(output);
|
|
|
|
sig.setValueAtTime(0, 0);
|
|
|
|
sig.linearRampToValueAtTime(0.5, 0.5);
|
|
|
|
sig.linearRampToValueAtTime(0, 1);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time < 0.5){
|
|
|
|
expect(sample).to.be.closeTo(time, 0.01);
|
|
|
|
} else {
|
|
|
|
expect(sample).to.be.closeTo(1 - time, 0.01);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-05-25 22:24:45 +00:00
|
|
|
it("can disconnect from all the connected notes", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var output0 = new Signal(1).toMaster();
|
|
|
|
var output1 = new Signal(1).toMaster();
|
|
|
|
var sig = new Signal(0).fan(output0, output1);
|
|
|
|
sig.disconnect();
|
|
|
|
sig.setValueAtTime(0, 0);
|
|
|
|
sig.linearRampToValueAtTime(0.5, 0.5);
|
|
|
|
sig.linearRampToValueAtTime(0, 1);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.equal(0);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can disconnect from a specific node", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var output = new Signal(1).toMaster();
|
|
|
|
var sig = new Signal(0).connect(output);
|
|
|
|
sig.disconnect(output);
|
|
|
|
sig.setValueAtTime(0, 0);
|
|
|
|
sig.linearRampToValueAtTime(0.5, 0.5);
|
|
|
|
sig.linearRampToValueAtTime(0, 1);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.equal(0);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-02-04 18:05:06 +00:00
|
|
|
it("can schedule multiple automations from a connected signal through a multiple nodes", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var output = new Signal(0).toMaster();
|
|
|
|
var proxy = new Signal(0).connect(output);
|
|
|
|
var gain = new Gain(1).connect(proxy);
|
|
|
|
var sig = new Signal(0).connect(gain);
|
|
|
|
sig.setValueAtTime(0, 0);
|
|
|
|
sig.linearRampToValueAtTime(0.5, 0.5);
|
|
|
|
sig.linearRampToValueAtTime(0, 1);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time < 0.5){
|
|
|
|
expect(sample).to.be.closeTo(time, 0.01);
|
|
|
|
} else {
|
|
|
|
expect(sample).to.be.closeTo(1 - time, 0.01);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can cancel an automation", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return ConstantOutput(function(){
|
|
|
|
var sig = new Signal(1).toMaster();
|
2016-03-04 21:00:05 +00:00
|
|
|
sig.setValueAtTime(4, 0.1);
|
|
|
|
sig.exponentialRampToValueAtTime(3, 0.2);
|
|
|
|
sig.cancelScheduledValues(0);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 1);
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
|
2018-01-03 20:38:04 +00:00
|
|
|
it("can cancel and hold a linear automation curve", function(){
|
2017-08-31 16:41:15 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
|
|
|
sig.linearRampTo(2, 1);
|
2017-12-30 16:26:29 +00:00
|
|
|
sig.cancelAndHoldAtTime(0.5);
|
2017-08-31 16:41:15 +00:00
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.getValueAtTime(0)).to.be.closeTo(0, 0.1);
|
|
|
|
expect(buffer.getValueAtTime(0.25)).to.be.closeTo(0.5, 0.1);
|
|
|
|
expect(buffer.getValueAtTime(0.5)).to.be.closeTo(1, 0.1);
|
|
|
|
expect(buffer.getValueAtTime(0.75)).to.be.closeTo(1, 0.1);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-01-03 20:38:04 +00:00
|
|
|
it("can cancel and hold an exponential automation curve", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1).toMaster();
|
|
|
|
sig.exponentialRampTo(2, 1);
|
|
|
|
sig.cancelAndHoldAtTime(0.5);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.getValueAtTime(0)).to.be.closeTo(1, 0.1);
|
|
|
|
expect(buffer.getValueAtTime(0.25)).to.be.closeTo(1.2, 0.1);
|
|
|
|
expect(buffer.getValueAtTime(0.5)).to.be.closeTo(1.4, 0.1);
|
|
|
|
expect(buffer.getValueAtTime(0.75)).to.be.closeTo(1.4, 0.1);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set a linear ramp from the current time", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
2017-08-31 16:41:15 +00:00
|
|
|
sig.linearRampTo(2, 0.3);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 0.5).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time > 0.3){
|
|
|
|
expect(sample).to.be.closeTo(2, 0.02);
|
|
|
|
}
|
|
|
|
});
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set an linear ramp in the future", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1).toMaster();
|
2017-08-31 16:41:15 +00:00
|
|
|
sig.linearRampTo(50, 0.3, 0.2);
|
2017-12-30 01:06:21 +00:00
|
|
|
}, 0.7).then(function(buffer){
|
2017-02-20 21:40:41 +00:00
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time >= 0.6){
|
|
|
|
expect(sample).to.be.closeTo(50, 0.5);
|
|
|
|
} else if (time < 0.2){
|
2017-12-30 01:06:21 +00:00
|
|
|
expect(sample).to.closeTo(1, 0.01);
|
2017-02-20 21:40:41 +00:00
|
|
|
}
|
|
|
|
});
|
2016-05-18 01:59:36 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set a exponential approach ramp from the current time", function(){
|
2017-09-13 15:19:12 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
|
|
|
sig.targetRampTo(1, 0.3);
|
|
|
|
}, 0.5).then(function(buffer){
|
|
|
|
expect(buffer.getValueAtTime(0)).to.be.below(0.0001);
|
|
|
|
expect(buffer.getValueAtTime(0.3)).to.be.closeTo(1, 0.02);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set an exponential approach ramp in the future", function(){
|
2017-09-13 15:19:12 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1).toMaster();
|
|
|
|
sig.targetRampTo(50, 0.3, 0.2);
|
|
|
|
}, 0.7).then(function(buffer){
|
|
|
|
expect(buffer.getValueAtTime(0)).to.be.closeTo(1, 0.0001);
|
|
|
|
expect(buffer.getValueAtTime(0.2)).to.be.closeTo(1, 0.0001);
|
|
|
|
expect(buffer.getValueAtTime(0.6)).to.be.closeTo(50, 0.5);
|
|
|
|
});
|
|
|
|
});
|
2016-05-18 01:59:36 +00:00
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set an exponential ramp from the current time", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1).toMaster();
|
2017-08-31 16:41:15 +00:00
|
|
|
sig.exponentialRampTo(50, 0.4);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 0.6).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time >= 0.4){
|
|
|
|
expect(sample).to.be.closeTo(50, 0.5);
|
|
|
|
} else if (time < 0.39){
|
|
|
|
expect(sample).to.be.lessThan(50);
|
|
|
|
}
|
|
|
|
});
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set an exponential ramp in the future", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1).toMaster();
|
2017-08-31 16:41:15 +00:00
|
|
|
sig.exponentialRampTo(50, 0.3, 0.2);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 0.8).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time >= 0.6){
|
|
|
|
expect(sample).to.be.closeTo(50, 0.5);
|
|
|
|
} else if (time < 0.2){
|
|
|
|
expect(sample).to.equal(1);
|
|
|
|
}
|
|
|
|
});
|
2016-05-18 01:59:36 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("rampTo ramps from the current value", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(3).toMaster();
|
2015-08-24 21:29:19 +00:00
|
|
|
sig.rampTo(0.2, 0.1);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 0.4).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time >= 0.1){
|
|
|
|
expect(sample).to.be.closeTo(0.2, 0.1);
|
|
|
|
} else {
|
|
|
|
expect(sample).to.be.greaterThan(0.2);
|
|
|
|
}
|
|
|
|
});
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
});
|
2016-05-18 01:59:36 +00:00
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("rampTo ramps from the current value at a specific time", function(){
|
2017-02-20 21:40:41 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
2016-05-18 01:59:36 +00:00
|
|
|
sig.rampTo(2, 0.1, 0.4);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 0.6).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time < 0.4){
|
2017-12-30 16:26:29 +00:00
|
|
|
expect(sample).to.be.closeTo(0, 0.1);
|
|
|
|
} else if (time > 0.5){
|
|
|
|
expect(sample).to.be.closeTo(2, 0.1);
|
|
|
|
}
|
2017-02-20 21:40:41 +00:00
|
|
|
});
|
2016-05-18 01:59:36 +00:00
|
|
|
});
|
|
|
|
});
|
2017-08-31 16:41:15 +00:00
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set a value curve", function(){
|
2017-09-20 23:05:00 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
|
|
|
sig.setValueCurveAtTime([0, 1, 0.5, 0.2], 0, 1);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.getValueAtTime(0)).to.be.closeTo(0, 0.01);
|
|
|
|
expect(buffer.getValueAtTime(0.33/2)).to.be.closeTo(0.5, 0.01);
|
|
|
|
expect(buffer.getValueAtTime(0.33)).to.be.closeTo(1, 0.02);
|
|
|
|
expect(buffer.getValueAtTime(0.66)).to.be.closeTo(0.5, 0.02);
|
|
|
|
expect(buffer.getValueAtTime(0.99)).to.be.closeTo(0.2, 0.02);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set a value curve in the future", function(){
|
2017-09-20 23:05:00 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
|
|
|
sig.setValueCurveAtTime([0, 1, 0.5, 0.2], 0.5, 1);
|
|
|
|
}, 1.5).then(function(buffer){
|
|
|
|
expect(buffer.getValueAtTime(0 + 0.5)).to.be.closeTo(0, 0.01);
|
|
|
|
expect(buffer.getValueAtTime(0.33/2 + 0.5)).to.be.closeTo(0.5, 0.01);
|
|
|
|
expect(buffer.getValueAtTime(0.33 + 0.5)).to.be.closeTo(1, 0.02);
|
|
|
|
expect(buffer.getValueAtTime(0.66 + 0.5)).to.be.closeTo(0.5, 0.02);
|
|
|
|
expect(buffer.getValueAtTime(0.99 + 0.5)).to.be.closeTo(0.2, 0.02);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-30 16:26:29 +00:00
|
|
|
it("can set an exponential approach", function(){
|
2017-09-20 23:05:00 +00:00
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(0).toMaster();
|
2017-12-30 01:00:22 +00:00
|
|
|
sig.exponentialApproachValueAtTime(2, 0.1, 0.5);
|
2017-09-20 23:05:00 +00:00
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.getValueAtTime(0)).to.be.closeTo(0, 0.01);
|
|
|
|
expect(buffer.getValueAtTime(0.1)).to.be.closeTo(0, 0.01);
|
|
|
|
expect(buffer.getValueAtTime(0.4)).to.be.closeTo(1.9, 0.1);
|
|
|
|
expect(buffer.getValueAtTime(0.6)).to.be.closeTo(2, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
|
2018-05-25 22:24:45 +00:00
|
|
|
context("Proxy", function(){
|
|
|
|
|
|
|
|
it("uses proxy connections when controling an audio param", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var gainNode = new Gain(1).toMaster();
|
|
|
|
var sig = new Signal(1).connect(gainNode);
|
|
|
|
var proxyControl = new Signal(2).connect(gainNode.gain);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(2, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
/*it("proxy does not actually output any signal when connected to a signal", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1);
|
|
|
|
var proxyControl = new Signal(2).connect(sig);
|
|
|
|
proxyControl._constantSource.toMaster();
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(0, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("proxy does not actually output any signal when connected from a signal", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1);
|
|
|
|
var proxyControl = new Signal(2).connect(sig);
|
|
|
|
sig._constantSource.toMaster();
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(0, 0.01);
|
|
|
|
});
|
|
|
|
});*/
|
|
|
|
|
|
|
|
it("if the lead proxy becomes a signal, all connected proxies become signals", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1);
|
|
|
|
var proxyControl = new Signal(2).connect(sig);
|
|
|
|
sig._constantSource.toMaster();
|
|
|
|
var gainNode = new Gain().connect(proxyControl);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(2, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
/*it("if the final proxy becomes a signal, not all connected proxies become signals", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1);
|
|
|
|
var proxyControl = new Signal(2).connect(sig);
|
|
|
|
proxyControl._constantSource.toMaster();
|
|
|
|
var gainNode = new Gain().connect(sig);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(0, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("all proxied signals report the same values", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var sig = new Signal(1);
|
|
|
|
var proxyControl = new Signal(2).connect(sig);
|
|
|
|
proxyControl.setValueAtTime(1, 0.5);
|
|
|
|
expect(sig.getValueAtTime(0)).to.be.closeTo(2, 0.01);
|
|
|
|
expect(proxyControl.getValueAtTime(0)).to.be.closeTo(2, 0.01);
|
|
|
|
expect(sig.getValueAtTime(0.5)).to.be.closeTo(1, 0.01);
|
|
|
|
expect(proxyControl.getValueAtTime(0.5)).to.be.closeTo(1, 0.01);
|
|
|
|
}, 1);
|
|
|
|
});*/
|
|
|
|
|
|
|
|
it("connection from a non-param will start the output", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var gainNode = new Gain(1);
|
|
|
|
var proxyControl = new Signal(2);
|
|
|
|
gainNode.connect(proxyControl);
|
|
|
|
proxyControl._constantSource.toMaster();
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(2, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can disconnect a proxy when not live", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var gainNode = new Gain(1).toMaster();
|
|
|
|
var sig = new Signal(1).connect(gainNode);
|
|
|
|
var proxyControl = new Signal(2).connect(gainNode.gain);
|
|
|
|
proxyControl.disconnect();
|
|
|
|
proxyControl.setValueAtTime(3, 0);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(2, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can disconnect a proxy from a specific output when not live", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var gainNode = new Gain(1).toMaster();
|
|
|
|
var sig = new Signal(1).connect(gainNode);
|
|
|
|
var proxyControl = new Signal(2).connect(gainNode.gain);
|
|
|
|
proxyControl.disconnect(gainNode.gain);
|
|
|
|
proxyControl.setValueAtTime(3, 0);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(2, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can disconnect a proxy when live", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var gainNode = new Gain(1).toMaster();
|
|
|
|
var sig = new Signal(1).connect(gainNode);
|
|
|
|
var proxyControl = new Signal(2).connect(gainNode.gain);
|
|
|
|
proxyControl.disconnect();
|
|
|
|
proxyControl.setValueAtTime(3, 0);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(2, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can disconnect a proxy from a specific output when live", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var gainNode = new Gain(1).toMaster();
|
|
|
|
var sig = new Signal(1).connect(gainNode);
|
|
|
|
var proxyControl = new Signal(2).connect(gainNode.gain);
|
|
|
|
proxyControl.disconnect(gainNode.gain);
|
|
|
|
proxyControl.setValueAtTime(3, 0);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(2, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("proxy becomes normal signal when signal is connected to it", function(){
|
|
|
|
return Offline(function(){
|
|
|
|
var gainNode = new Gain(1).toMaster();
|
|
|
|
var sig = new Signal(1).connect(gainNode);
|
|
|
|
var proxyControl = new Signal(2).connect(gainNode.gain);
|
|
|
|
proxyControl.disconnect(gainNode.gain);
|
|
|
|
proxyControl.setValueAtTime(3, 0);
|
|
|
|
}, 1).then(function(buffer){
|
|
|
|
expect(buffer.value()).to.be.closeTo(2, 0.01);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2015-08-24 21:29:19 +00:00
|
|
|
context("Units", function(){
|
|
|
|
|
|
|
|
it("can be created with specific units", function(){
|
|
|
|
var signal = new Signal(0, Tone.Type.BPM);
|
|
|
|
expect(signal.units).to.equal(Tone.Type.BPM);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can evaluate the given units", function(){
|
|
|
|
var signal = new Signal(2, Tone.Type.Time);
|
|
|
|
signal.value = "4n";
|
|
|
|
expect(signal.value).to.be.closeTo(0.5, 0.001);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
2017-02-20 21:40:41 +00:00
|
|
|
it("converts the given units when passed in the constructor", function(){
|
|
|
|
return ConstantOutput(function(){
|
|
|
|
var signal = new Signal({
|
2015-10-21 14:55:56 +00:00
|
|
|
"value" : -10,
|
|
|
|
"units" : Tone.Type.Decibels,
|
2017-02-20 21:40:41 +00:00
|
|
|
}).toMaster();
|
|
|
|
}, 0.315);
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
|
2017-02-20 21:40:41 +00:00
|
|
|
it("can be set to not convert the given units", function(){
|
|
|
|
return ConstantOutput(function(){
|
|
|
|
var signal = new Signal({
|
2015-10-21 14:55:56 +00:00
|
|
|
"value" : -10,
|
|
|
|
"units" : Tone.Type.Decibels,
|
|
|
|
"convert" : false
|
2017-02-20 21:40:41 +00:00
|
|
|
}).toMaster();
|
|
|
|
}, -10);
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it("converts Frequency units", function(){
|
|
|
|
var signal = new Signal("50hz", Tone.Type.Frequency);
|
|
|
|
expect(signal.value).to.be.closeTo(50, 0.01);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("converts Time units", function(){
|
|
|
|
var signal = new Signal("4n", Tone.Type.Time);
|
|
|
|
expect(signal.value).to.be.closeTo(0.5, 0.01);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("converts NormalRange units", function(){
|
|
|
|
var signal = new Signal(2, Tone.Type.NormalRange);
|
|
|
|
expect(signal.value).to.be.closeTo(1, 0.01);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("converts AudioRange units", function(){
|
|
|
|
var signal = new Signal(-2, Tone.Type.AudioRange);
|
|
|
|
expect(signal.value).to.be.closeTo(-1, 0.01);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("converts Positive units", function(){
|
|
|
|
var signal = new Signal(-2, Tone.Type.Positive);
|
|
|
|
expect(signal.value).to.be.closeTo(0, 0.01);
|
|
|
|
signal.dispose();
|
|
|
|
});
|
2017-08-31 16:41:15 +00:00
|
|
|
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
2015-08-31 19:16:20 +00:00
|
|
|
|
|
|
|
context("Transport Syncing", function(){
|
|
|
|
|
2017-02-20 21:40:41 +00:00
|
|
|
it("maintains its original value after being synced to the transport", function(){
|
|
|
|
return ConstantOutput(function(Transport){
|
|
|
|
var sig = new Signal(3).toMaster();
|
2015-08-31 19:16:20 +00:00
|
|
|
Transport.syncSignal(sig);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 3);
|
2015-08-31 19:16:20 +00:00
|
|
|
});
|
|
|
|
|
2017-02-20 21:40:41 +00:00
|
|
|
it("keeps the ratio when the bpm changes", function(){
|
|
|
|
return ConstantOutput(function(Transport){
|
2015-08-31 19:16:20 +00:00
|
|
|
Transport.bpm.value = 120;
|
2017-02-20 21:40:41 +00:00
|
|
|
var sig = new Signal(5).toMaster();
|
2015-08-31 19:16:20 +00:00
|
|
|
Transport.syncSignal(sig);
|
|
|
|
Transport.bpm.value = 240;
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 10);
|
2015-08-31 19:16:20 +00:00
|
|
|
});
|
|
|
|
|
2017-02-20 21:40:41 +00:00
|
|
|
it("can ramp along with the bpm", function(){
|
|
|
|
return Offline(function(Transport){
|
2015-08-31 19:16:20 +00:00
|
|
|
Transport.bpm.value = 120;
|
2017-02-20 21:40:41 +00:00
|
|
|
var sig = new Signal(2).toMaster();
|
2015-08-31 19:16:20 +00:00
|
|
|
Transport.syncSignal(sig);
|
|
|
|
Transport.bpm.rampTo(240, 0.5);
|
2017-02-20 21:40:41 +00:00
|
|
|
}).then(function(buffer){
|
|
|
|
buffer.forEach(function(sample, time){
|
|
|
|
if (time >= 0.5){
|
|
|
|
expect(sample).to.be.closeTo(4, 0.04);
|
|
|
|
} else if (time < 0.4){
|
|
|
|
expect(sample).to.be.within(1.95, 3);
|
|
|
|
}
|
|
|
|
});
|
2015-08-31 19:16:20 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-02-20 21:40:41 +00:00
|
|
|
it("returns to the original value when unsynced", function(){
|
|
|
|
return ConstantOutput(function(Transport){
|
2015-08-31 19:16:20 +00:00
|
|
|
Transport.bpm.value = 120;
|
2017-02-20 21:40:41 +00:00
|
|
|
var sig = new Signal(5).toMaster();
|
2015-08-31 19:16:20 +00:00
|
|
|
Transport.syncSignal(sig);
|
|
|
|
Transport.bpm.value = 240;
|
|
|
|
Transport.unsyncSignal(sig);
|
2017-02-20 21:40:41 +00:00
|
|
|
}, 5);
|
2015-08-31 19:16:20 +00:00
|
|
|
});
|
|
|
|
});
|
2016-09-18 23:28:20 +00:00
|
|
|
|
2015-08-24 21:29:19 +00:00
|
|
|
});
|
2017-08-31 16:41:15 +00:00
|
|
|
});
|