mirror of
https://github.com/Tonejs/Tone.js
synced 2025-01-14 21:03:55 +00:00
78 lines
2.2 KiB
TypeScript
78 lines
2.2 KiB
TypeScript
|
import { AutoPanner } from "./AutoPanner";
|
||
|
import { BasicTests } from "test/helper/Basic";
|
||
|
import { EffectTests } from "test/helper/EffectTests";
|
||
|
import { Offline } from "test/helper/Offline";
|
||
|
import { expect } from "chai";
|
||
|
|
||
|
describe("AutoPanner", () => {
|
||
|
BasicTests(AutoPanner);
|
||
|
EffectTests(AutoPanner);
|
||
|
|
||
|
context("API", () => {
|
||
|
|
||
|
it("can pass in options in the constructor", () => {
|
||
|
const autoPanner = new AutoPanner({
|
||
|
type: "sawtooth",
|
||
|
depth: 0.2
|
||
|
});
|
||
|
expect(autoPanner.depth.value).to.be.closeTo(0.2, 0.01);
|
||
|
expect(autoPanner.type).to.equal("sawtooth");
|
||
|
autoPanner.dispose();
|
||
|
});
|
||
|
|
||
|
it("can be started and stopped", () => {
|
||
|
const autoPanner = new AutoPanner();
|
||
|
autoPanner.start().stop("+0.2");
|
||
|
autoPanner.dispose();
|
||
|
});
|
||
|
|
||
|
it("can get/set the options", () => {
|
||
|
const autoPanner = new AutoPanner();
|
||
|
autoPanner.set({
|
||
|
frequency: 2.4,
|
||
|
type: "triangle"
|
||
|
});
|
||
|
expect(autoPanner.get().frequency).to.be.closeTo(2.4, 0.01);
|
||
|
expect(autoPanner.get().type).to.equal("triangle");
|
||
|
autoPanner.dispose();
|
||
|
});
|
||
|
|
||
|
it("can set the frequency and depth", () => {
|
||
|
const autoPanner = new AutoPanner();
|
||
|
autoPanner.depth.value = 0.4;
|
||
|
autoPanner.frequency.value = 0.4;
|
||
|
expect(autoPanner.depth.value).to.be.closeTo(0.4, 0.01);
|
||
|
expect(autoPanner.frequency.value).to.be.closeTo(0.4, 0.01);
|
||
|
autoPanner.dispose();
|
||
|
});
|
||
|
|
||
|
it("can sync the frequency to the transport", () => {
|
||
|
return Offline(({ transport }) => {
|
||
|
let panner = new AutoPanner(2);
|
||
|
panner.sync();
|
||
|
panner.frequency.toDestination();
|
||
|
transport.bpm.setValueAtTime(transport.bpm.value * 2, 0.05);
|
||
|
// transport.start(0)
|
||
|
}, 0.1).then((buffer) => {
|
||
|
expect(buffer.getValueAtTime(0)).to.be.closeTo(2, 0.1);
|
||
|
expect(buffer.getValueAtTime(0.05)).to.be.closeTo(4, 0.1);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
it("can unsync the frequency to the transport", () => {
|
||
|
return Offline(({ transport }) => {
|
||
|
let panner = new AutoPanner(2);
|
||
|
panner.sync();
|
||
|
panner.frequency.toDestination();
|
||
|
transport.bpm.setValueAtTime(transport.bpm.value * 2, 0.05);
|
||
|
panner.unsync();
|
||
|
// transport.start(0)
|
||
|
}, 0.1).then((buffer) => {
|
||
|
expect(buffer.getValueAtTime(0)).to.be.closeTo(2, 0.1);
|
||
|
expect(buffer.getValueAtTime(0.05)).to.be.closeTo(2, 0.1);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|