LogarithmPlotter/common/test/math/domain.mjs
Ad5001 6025742e86
All checks were successful
continuous-integration/drone/push Build is passing
Fixing bugs.
2025-01-06 16:23:06 +01:00

108 lines
5.6 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/**
* LogarithmPlotter - 2D plotter software to make BODE plots, sequences and distribution functions.
* Copyright (C) 2021-2024 Ad5001
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
import { describe, it } from "mocha"
import { expect } from "chai"
import { Domain, EmptySet, parseDomainSimple } from "../../src/math/domain.mjs"
describe("math.domain", function() {
describe("#parseDomainSimple", function() {
it("returns empty sets when a domain cannot be parsed", function() {
expect(parseDomainSimple("∅")).to.be.an.instanceof(EmptySet)
expect(parseDomainSimple("O")).to.be.an.instanceof(EmptySet)
expect(parseDomainSimple("AAAAAAAAA")).to.be.an.instanceof(EmptySet)
expect(parseDomainSimple("???")).to.be.an.instanceof(EmptySet)
expect(parseDomainSimple("∅").latexMarkup).to.equal("\\emptyset")
expect(parseDomainSimple("???").toString()).to.equal("∅")
expect(parseDomainSimple("∅").includes(0)).to.be.false
expect(parseDomainSimple("∅").includes(Infinity)).to.be.false
expect(parseDomainSimple("∅").includes(-3)).to.be.false
})
it("returns predefined domains", function() {
const predefinedToCheck = [
// Real domains
{ domain: Domain.R, shortcuts: ["R", ""] },
// Zero exclusive real domains
{ domain: Domain.RE, shortcuts: ["RE", "R*", "*"] },
// Real positive domains
{ domain: Domain.RP, shortcuts: ["RP", "R+", "ℝ⁺", "+"] },
// Zero-exclusive real positive domains
{ domain: Domain.RPE, shortcuts: ["RPE", "REP", "R+*", "R*+", "*⁺", "ℝ⁺*", "*+", "+*"] },
// Real negative domain
{ domain: Domain.RM, shortcuts: ["RM", "R-", "ℝ⁻", "-"] },
// Zero-exclusive real negative domains
{ domain: Domain.RME, shortcuts: ["RME", "REM", "R-*", "R*-", "ℝ⁻*", "*⁻", "-*", "*-"] },
// Natural integers domain
{ domain: Domain.N, shortcuts: ["", "N", "ZP", "Z+", "ℤ⁺", "+"] },
// Zero-exclusive natural integers domain
{ domain: Domain.NE, shortcuts: ["NE", "NP", "N*", "N+", "*", "ℕ⁺", "+", "ZPE", "ZEP", "Z+*", "Z*+", "ℤ⁺*", "*⁺", "+*", "*+"] },
// Logarithmic natural domains
{ domain: Domain.NLog, shortcuts: ["NLOG", "ℕˡᵒᵍ", "LOG"] },
// All integers domains
{ domain: Domain.Z, shortcuts: ["Z", ""] },
// Zero-exclusive all integers domain
{ domain: Domain.ZE, shortcuts: ["ZE", "Z*", "*"] },
// Negative integers domain
{ domain: Domain.ZM, shortcuts: ["ZM", "Z-", "ℤ⁻", "-"] },
// Zero-exclusive negative integers domain
{ domain: Domain.ZME, shortcuts: ["ZME", "ZEM", "Z-*", "Z*-", "ℤ⁻*", "*⁻", "-*", "*-"] },
]
// Real domains
for(const { domain, shortcuts } of predefinedToCheck)
for(const shortcut of shortcuts)
expect(parseDomainSimple(shortcut)).to.be.equal(domain)
})
it("returns parsed ranges", function() {
const parsedClosed = parseDomainSimple("[1;3]")
expect(parsedClosed.includes(1)).to.be.true
expect(parsedClosed.includes(2.4)).to.be.true
expect(parsedClosed.includes(3)).to.be.true
expect(parsedClosed.includes(3.01)).to.be.false
expect(parsedClosed.includes(0.99)).to.be.false
const parsedOpen = parseDomainSimple("]1;3[")
expect(parsedOpen.includes(1)).to.be.false
expect(parsedOpen.includes(3)).to.be.false
expect(parsedOpen.includes(2.4)).to.be.true
expect(parsedOpen.includes(1.01)).to.be.true
expect(parsedOpen.includes(2.99)).to.be.true
const parsedOpenBefore = parseDomainSimple("]1;3]")
expect(parsedOpenBefore.includes(1)).to.be.false
expect(parsedOpenBefore.includes(3)).to.be.true
expect(parsedOpenBefore.includes(2.4)).to.be.true
expect(parsedOpenBefore.includes(1.01)).to.be.true
expect(parsedOpenBefore.includes(3.01)).to.be.false
const parsedOpenAfter = parseDomainSimple("[1;3[")
expect(parsedOpenAfter.includes(1)).to.be.true
expect(parsedOpenAfter.includes(3)).to.be.false
expect(parsedOpenAfter.includes(2.4)).to.be.true
expect(parsedOpenAfter.includes(0.99)).to.be.false
expect(parsedOpenAfter.includes(2.99)).to.be.true
})
it("does not parse invalid ranges", function() {
expect(() => parseDomainSimple("]1;2;3[")).to.throw
expect(() => parseDomainSimple("]1,2;3[")).to.throw
expect(() => parseDomainSimple("](12);3[")).to.throw
})
})
})