stringzy
Version:
A versatile string manipulation library providing a range of text utilities for JavaScript and Node.js applications.
29 lines (28 loc) • 1.48 kB
JavaScript
;
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const node_test_1 = require("node:test");
const node_assert_1 = __importDefault(require("node:assert"));
const complexity_1 = require("../../analyzing/complexity");
(0, node_test_1.describe)('complexity', () => {
(0, node_test_1.it)('returns 0s for empty string', () => {
node_assert_1.default.deepStrictEqual((0, complexity_1.complexity)(''), { score: 0, uniqueness: 0, length: 0 });
});
(0, node_test_1.it)('returns correct result for simple string', () => {
const result = (0, complexity_1.complexity)('abc');
node_assert_1.default.strictEqual(typeof result.score, 'number');
node_assert_1.default.strictEqual(typeof result.uniqueness, 'number');
node_assert_1.default.strictEqual(result.length, 3);
});
(0, node_test_1.it)('returns correct result for complex string', () => {
const result = (0, complexity_1.complexity)('aA1!aA1!');
node_assert_1.default.ok(result.score > 0);
node_assert_1.default.ok(result.uniqueness > 0);
node_assert_1.default.strictEqual(result.length, 8);
});
(0, node_test_1.it)('throws if input is not a string', () => {
node_assert_1.default.throws(() => (0, complexity_1.complexity)(123), /Input must be a string/);
});
});