// import APITest from "helper/APITest"; import { expect } from "chai"; // import Source from "Tone/source/Source"; // import OutputAudioStereo from "helper/OutputAudioStereo"; // import Test from "helper/Test"; import { Offline } from "test/helper/Offline"; import { OutputAudio } from "test/helper/OutputAudio"; import { connectFrom, connectTo } from "./Connect"; export function SourceTests(Constr, args?): void { context("Source Tests", () => { // it("extends Tone.Source", () => { // const instance = new Constr(args); // expect(instance).to.be.an.instanceof(Source); // instance.dispose(); // }); it("can connect the output", () => { const instance = new Constr(args); instance.connect(connectTo()); instance.dispose(); }); it.skip("has no input", () => { const instance = new Constr(args); // has no input expect(() => { connectFrom().connect(instance); }).throws(Error); instance.dispose(); }); it("starts and stops", () => { return Offline(() => { const instance = new Constr(args); expect(instance.state).to.equal("stopped"); instance.start(0).stop(0.2); return (time) => { if (time >= 0 && time < 0.2) { expect(instance.state).to.equal("started"); } else if (time > 0.2) { expect(instance.state).to.equal("stopped"); } }; }, 0.3); }); it("makes a sound", () => { return OutputAudio(() => { const instance = new Constr(args); instance.toMaster(); instance.start(); }); }); // it("produces sound in both channels", () => { // return OutputAudioStereo(() => { // const instance = new Constr(args); // instance.toMaster(); // instance.start(); // }); // }); it("be scheduled to start in the future", () => { return Offline(() => { const instance = new Constr(args).toMaster(); instance.start(0.1); }, 0.3).then((buffer) => { buffer.forEach((sample, time) => { if (sample > 0) { expect(time).to.be.at.least(0.099); } }); }); }); it("makes no sound if it is started and then stopped with a time at or before the start time", () => { return Offline(() => { const instance = new Constr(args).toMaster(); instance.start(0.1).stop(0.05); }, 0.3).then((buffer) => { expect(buffer.isSilent()).to.equal(true); }); }); it("can be muted", () => { return Offline(() => { const instance = new Constr(args).toMaster(); instance.start(0); instance.mute = true; }, 0.3).then((buffer) => { expect(buffer.isSilent()).to.equal(true); }); }); it("be scheduled to stop in the future", () => { return Offline(() => { const instance = new Constr(args).toMaster(); instance.start(0).stop(0.2); }, 0.3).then((buffer) => { buffer.forEach((sample, time) => { if (time > 0.2) { expect(sample).to.equal(0); } }); }); }); it("can be restarted", () => { return Offline(() => { const instance = new Constr(args).toMaster(); instance.start(0).stop(0.2); instance.restart(0.1); instance.stop(0.25); }, 0.32).then((buffer) => { expect(buffer.getRmsAtTime(0)).to.be.gt(0); expect(buffer.getRmsAtTime(0.1)).to.be.gt(0); expect(buffer.getRmsAtTime(0.2)).to.be.gt(0); expect(buffer.getRmsAtTime(0.23)).to.be.gt(0); expect(buffer.getRmsAtTime(0.3)).to.equal(0); }); }); }); }