mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-02-06 17:47:49 +00:00
wip: migrate to bun
This commit is contained in:
86
test/round-methods.spec.ts
Normal file
86
test/round-methods.spec.ts
Normal file
@@ -0,0 +1,86 @@
|
||||
import assert from 'node:assert';
|
||||
import lodashStable from 'lodash';
|
||||
import { _, MAX_SAFE_INTEGER, stubFalse } from './utils';
|
||||
import round from '../src/round';
|
||||
|
||||
describe('round methods', () => {
|
||||
lodashStable.each(['ceil', 'floor', 'round'], (methodName) => {
|
||||
const func = _[methodName],
|
||||
isCeil = methodName == 'ceil',
|
||||
isFloor = methodName == 'floor';
|
||||
|
||||
it(`\`_.${methodName}\` should return a rounded number without a precision`, () => {
|
||||
const actual = func(4.006);
|
||||
assert.strictEqual(actual, isCeil ? 5 : 4);
|
||||
});
|
||||
|
||||
it(`\`_.${methodName}\` should work with a precision of \`0\``, () => {
|
||||
const actual = func(4.006, 0);
|
||||
assert.strictEqual(actual, isCeil ? 5 : 4);
|
||||
});
|
||||
|
||||
it(`\`_.${methodName}\` should work with a positive precision`, () => {
|
||||
let actual = func(4.016, 2);
|
||||
assert.strictEqual(actual, isFloor ? 4.01 : 4.02);
|
||||
|
||||
actual = func(4.1, 2);
|
||||
assert.strictEqual(actual, 4.1);
|
||||
});
|
||||
|
||||
it(`\`_.${methodName}\` should work with a negative precision`, () => {
|
||||
const actual = func(4160, -2);
|
||||
assert.strictEqual(actual, isFloor ? 4100 : 4200);
|
||||
});
|
||||
|
||||
it(`\`_.${methodName}\` should coerce \`precision\` to an integer`, () => {
|
||||
let actual = func(4.006, NaN);
|
||||
assert.strictEqual(actual, isCeil ? 5 : 4);
|
||||
|
||||
const expected = isFloor ? 4.01 : 4.02;
|
||||
|
||||
actual = func(4.016, 2.6);
|
||||
assert.strictEqual(actual, expected);
|
||||
|
||||
actual = func(4.016, '+2');
|
||||
assert.strictEqual(actual, expected);
|
||||
});
|
||||
|
||||
it(`\`_.${methodName}\` should work with exponential notation and \`precision\``, () => {
|
||||
let actual = func(5e1, 2);
|
||||
assert.deepStrictEqual(actual, 50);
|
||||
|
||||
actual = func('5e', 1);
|
||||
assert.deepStrictEqual(actual, NaN);
|
||||
|
||||
actual = func('5e1e1', 1);
|
||||
assert.deepStrictEqual(actual, NaN);
|
||||
});
|
||||
|
||||
it(`\`_.${methodName}\` should preserve the sign of \`0\``, () => {
|
||||
const values = [[0], [-0], ['0'], ['-0'], [0, 1], [-0, 1], ['0', 1], ['-0', 1]],
|
||||
expected = [
|
||||
Infinity,
|
||||
-Infinity,
|
||||
Infinity,
|
||||
-Infinity,
|
||||
Infinity,
|
||||
-Infinity,
|
||||
Infinity,
|
||||
-Infinity,
|
||||
];
|
||||
|
||||
const actual = lodashStable.map(values, (args) => 1 / func.apply(undefined, args));
|
||||
|
||||
assert.deepStrictEqual(actual, expected);
|
||||
});
|
||||
|
||||
it(`\`_.${methodName}\` should not return \`NaN\` for large \`precision\` values`, () => {
|
||||
const results = [round(10.0000001, 1000), round(MAX_SAFE_INTEGER, 293)];
|
||||
|
||||
const expected = lodashStable.map(results, stubFalse),
|
||||
actual = lodashStable.map(results, lodashStable.isNaN);
|
||||
|
||||
assert.deepStrictEqual(actual, expected);
|
||||
});
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user