2019-09-20 04:31:43 +00:00
|
|
|
import { expect } from "chai";
|
2024-05-03 18:31:14 +00:00
|
|
|
import { ToneOscillatorNode } from "../../source/oscillator/ToneOscillatorNode.js";
|
|
|
|
import { assertRange, setLogger } from "./Debug.js";
|
|
|
|
import { theWindow } from "../context/AudioContext.js";
|
|
|
|
import { Oscillator } from "../../source/index.js";
|
|
|
|
import { Context } from "../context/Context.js";
|
2019-09-20 04:31:43 +00:00
|
|
|
|
|
|
|
describe("Debug", () => {
|
|
|
|
it("can log a class when that class is set to 'debug'", () => {
|
|
|
|
const osc = new ToneOscillatorNode();
|
|
|
|
osc.debug = true;
|
|
|
|
let loggerInvoked = false;
|
|
|
|
let warnInvoked = false;
|
|
|
|
setLogger({
|
2024-05-03 18:31:14 +00:00
|
|
|
log: () => (loggerInvoked = true),
|
|
|
|
warn: () => (warnInvoked = true),
|
2019-09-20 04:31:43 +00:00
|
|
|
});
|
|
|
|
osc.start();
|
|
|
|
expect(loggerInvoked).to.be.true;
|
|
|
|
expect(warnInvoked).to.be.false;
|
|
|
|
osc.dispose();
|
|
|
|
setLogger(console);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("can log a class when the window is set with that class name", () => {
|
|
|
|
// @ts-ignore
|
|
|
|
theWindow.TONE_DEBUG_CLASS = "ToneOscillatorNode";
|
|
|
|
const osc = new ToneOscillatorNode();
|
|
|
|
let loggerInvoked = false;
|
|
|
|
let warnInvoked = false;
|
|
|
|
setLogger({
|
2024-05-03 18:31:14 +00:00
|
|
|
log: () => (loggerInvoked = true),
|
|
|
|
warn: () => (warnInvoked = true),
|
2019-09-20 04:31:43 +00:00
|
|
|
});
|
|
|
|
osc.start();
|
|
|
|
expect(loggerInvoked).to.be.true;
|
|
|
|
expect(warnInvoked).to.be.false;
|
|
|
|
setLogger(console);
|
|
|
|
// @ts-ignore
|
|
|
|
theWindow.TONE_DEBUG_CLASS = undefined;
|
|
|
|
osc.dispose();
|
|
|
|
});
|
2019-10-09 16:38:10 +00:00
|
|
|
|
|
|
|
it("can assert a range", () => {
|
|
|
|
expect(() => {
|
|
|
|
assertRange(-1, 0, 1);
|
|
|
|
}).to.throw(RangeError);
|
|
|
|
|
|
|
|
expect(() => {
|
|
|
|
assertRange(2, 0, 1);
|
|
|
|
}).to.throw(RangeError);
|
2024-05-03 18:31:14 +00:00
|
|
|
|
2019-10-09 16:38:10 +00:00
|
|
|
expect(() => {
|
|
|
|
assertRange(0, 0);
|
|
|
|
}).to.not.throw(RangeError);
|
|
|
|
});
|
2019-11-11 16:43:43 +00:00
|
|
|
|
|
|
|
it("warns if console is not running", async () => {
|
2019-11-11 21:04:38 +00:00
|
|
|
const context = new Context();
|
|
|
|
await context.rawContext.suspend(0);
|
|
|
|
const osc = new Oscillator({ context });
|
2019-11-11 20:41:01 +00:00
|
|
|
let warnInvoked = false;
|
|
|
|
setLogger({
|
|
|
|
log: () => {},
|
2024-05-03 18:31:14 +00:00
|
|
|
warn: () => (warnInvoked = true),
|
2019-11-11 20:41:01 +00:00
|
|
|
});
|
|
|
|
osc.start();
|
2019-11-11 21:04:38 +00:00
|
|
|
expect(warnInvoked).to.be.true;
|
2019-11-11 20:41:01 +00:00
|
|
|
osc.dispose();
|
|
|
|
setLogger(console);
|
2019-11-11 21:04:38 +00:00
|
|
|
await context.close();
|
2019-11-11 16:43:43 +00:00
|
|
|
});
|
2019-09-20 04:31:43 +00:00
|
|
|
});
|