Tone.js/test/signal/TimelineSignal.js
Idicious 43c2e9b449 Increased general accurary of dbToGain method + updated test cases. (#279)
* Increased general accurary of dbToGain method + updated test cases.

* Increased test accuracy
2017-12-16 00:04:50 -05:00

182 lines
5.9 KiB
JavaScript

define(["Test", "Tone/signal/TimelineSignal", "helper/Offline", "Tone/type/Type"],
function (Test, TimelineSignal, Offline, Tone) {
describe("TimelineSignal", function(){
it("can be created and disposed", function(){
var sched = new TimelineSignal();
sched.dispose();
Test.wasDisposed(sched);
});
it("can schedule a change in the future", function(){
var sched = new TimelineSignal(1);
sched.setValueAtTime(2, 0.2);
sched.dispose();
});
it("can schedule a ramp in the future", function(){
var sched = new TimelineSignal(1);
sched.setValueAtTime(2, 0);
sched.linearRampToValueAtTime(0.1, 0.2);
sched.exponentialRampToValueAtTime(1, 0.4);
sched.setTargetAtTime(0.5, 0.45, 1);
sched.dispose();
});
it("can get a setValueAtTime value in the future", function(){
var sched = new TimelineSignal(1);
sched.setValueAtTime(0, 0);
sched.setValueAtTime(1, 1);
sched.setValueAtTime(2, 2);
sched.setValueAtTime(3, 3);
expect(sched.getValueAtTime(0)).to.equal(0);
expect(sched.getValueAtTime(1)).to.equal(1);
expect(sched.getValueAtTime(1.1)).to.equal(1);
expect(sched.getValueAtTime(2)).to.equal(2);
expect(sched.getValueAtTime(3)).to.equal(3);
expect(sched.getValueAtTime(4)).to.equal(3);
sched.dispose();
});
it("can get linear ramp value in the future", function(){
var sched = new TimelineSignal(1);
sched.setValueAtTime(0, 0);
sched.linearRampToValueAtTime(1, 1);
sched.linearRampToValueAtTime(0, 2);
expect(sched.getValueAtTime(0)).to.equal(0);
expect(sched.getValueAtTime(0.5)).to.equal(0.5);
expect(sched.getValueAtTime(1)).to.equal(1);
expect(sched.getValueAtTime(1.5)).to.equal(0.5);
expect(sched.getValueAtTime(2)).to.equal(0);
sched.dispose();
});
it("can get exponential ramp value in the future", function(){
var sched;
return Offline(function(){
sched = new TimelineSignal().toMaster();
sched.setValueAtTime(0.5, 0);
sched.exponentialRampToValueAtTime(1, 1);
sched.exponentialRampToValueAtTime(0.5, 2);
}, 2).then(function(buffer){
buffer.forEach(function(sample, time){
expect(sample).to.be.closeTo(sched.getValueAtTime(time), 0.01);
});
});
});
it("can get set target value in the future", function(){
var sched;
return Offline(function(){
sched = new TimelineSignal(1).toMaster();
sched.setValueAtTime(1, 0);
sched.setTargetAtTime(0.5, 0.5, 2);
}, 2).then(function(buffer){
buffer.forEach(function(sample, time){
expect(sample).to.be.closeTo(sched.getValueAtTime(time), 0.01);
});
});
});
it("can get set a curve in the future", function(){
var sched;
return Offline(function(){
sched = new TimelineSignal(1).toMaster();
sched.setValueCurveAtTime([0, 1, 0.2, 0.8, 0], 0, 1);
}, 1).then(function(buffer){
buffer.forEach(function(sample, time){
expect(sample).to.be.closeTo(sched.getValueAtTime(time), 0.03);
});
});
});
it("can scale a curve value", function(){
var sched;
return Offline(function(){
sched = new TimelineSignal(1).toMaster();
sched.setValueCurveAtTime([0, 1, 0], 0, 1, 0.5);
}, 1).then(function(buffer){
buffer.forEach(function(sample){
expect(sample).to.be.at.most(0.51);
});
});
});
it ("can cancel and hold an automation curve", function(){
return Offline(function(){
var sig = new TimelineSignal(0).toMaster();
sig.linearRampTo(2, 1);
sig.cancelAndHoldAtTime(0.5)
}, 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);
});
});
it("can match a complex scheduled curve", function(){
var sched;
return Offline(function(){
sched = new TimelineSignal(1).toMaster();
sched.setValueAtTime(0.2, 0.3);
sched.setTargetAtTime(0.5, 0.5, 2);
sched.setValueAtTime(0.4, 1);
sched.linearRampToValueAtTime(5, 1.4);
sched.exponentialRampToValueAtTime(2, 1.6);
sched.setValueAtTime(2.5, 2);
sched.linearRampToValueAtTime(2.4, 2.5);
sched.linearRampToValueAtTime(5, 3);
sched.setTargetAtTime(2, 3.5, 5);
sched.setValueCurveAtTime([0, 1, 0], 3.8, 0.2);
}, 4).then(function(buffer){
buffer.forEach(function(sample, time){
expect(sample).to.be.closeTo(sched.getValueAtTime(time), 0.01);
});
});
});
it("can schedule a linear ramp between two times", function(){
var sched = new TimelineSignal(0);
sched.linearRampToValueBetween(1, 1, 2);
expect(sched.getValueAtTime(0)).to.equal(0);
expect(sched.getValueAtTime(0.5)).to.equal(0);
expect(sched.getValueAtTime(1)).to.equal(0);
expect(sched.getValueAtTime(1.5)).to.equal(0.5);
expect(sched.getValueAtTime(2)).to.equal(1);
});
it("can get exponential ramp value between two times", function(){
var sched;
return Offline(function(){
sched = new TimelineSignal(1).toMaster();
sched.linearRampToValueBetween(3, 1, 2);
}, 3).then(function(buffer){
buffer.forEach(function(sample, time){
expect(sample).to.be.closeTo(sched.getValueAtTime(time), 0.01);
});
});
});
it("can automate values with different units", function(){
var sched;
return Offline(function(){
sched = new TimelineSignal(-10, Tone.Type.Decibels).toMaster();
sched.setValueAtTime(-5, 0);
sched.linearRampToValueAtTime(-12, 0.5);
sched.exponentialRampToValueBetween(-6, 1, 1.1);
}, 1.2).then(function(buffer){
buffer.forEach(function(sample, time){
if (time < 0.5){
expect(sample).to.be.within(Tone.dbToGain(-12.01), Tone.dbToGain(-4.99));
} else if (time < 1){
expect(sample).to.be.a.percentageFrom(Tone.dbToGain(-12), 0.02);
} else if (time > 1.1){
expect(sample).to.be.a.percentageFrom(Tone.dbToGain(-6), 0.02);
}
});
});
});
});
});