Tone.js/Tone/effect/AutoPanner.test.ts
2024-05-03 10:10:40 -04:00

90 lines
2.7 KiB
TypeScript

import { AutoPanner } from "./AutoPanner.js";
import { BasicTests } from "../../test/helper/Basic.js";
import { EffectTests } from "../../test/helper/EffectTests.js";
import { Offline } from "../../test/helper/Offline.js";
import { expect } from "chai";
import { CompareToFile } from "../../test/helper/CompareToFile.js";
import { Oscillator } from "../source/oscillator/Oscillator.js";
describe("AutoPanner", () => {
BasicTests(AutoPanner);
EffectTests(AutoPanner);
it("matches a file", () => {
return CompareToFile(() => {
const autoFilter = new AutoPanner({
type: "sine",
frequency: 3,
}).toDestination();
new Oscillator().connect(autoFilter).start();
autoFilter.start(0.2);
}, "autoPanner.wav", 0.01);
});
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 }) => {
const 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 }) => {
const 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);
});
});
});
});