lib: refactor to use min/max of validateNumber
Fix NumberIsNaN is called two times and change error code to ERR_OUT_OF_RANGE when RangeError is occurred in test. PR-URL: https://github.com/nodejs/node/pull/45772 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Darshan Sen <raisinten@gmail.com>
This commit is contained in:
parent
bfadee5e68
commit
88d71dc301
@ -3,7 +3,6 @@
|
||||
const {
|
||||
MapPrototypeEntries,
|
||||
NumberIsNaN,
|
||||
NumberIsInteger,
|
||||
NumberMAX_SAFE_INTEGER,
|
||||
ObjectFromEntries,
|
||||
ReflectConstruct,
|
||||
@ -186,9 +185,8 @@ class Histogram {
|
||||
if (!isHistogram(this))
|
||||
throw new ERR_INVALID_THIS('Histogram');
|
||||
validateNumber(percentile, 'percentile');
|
||||
|
||||
if (NumberIsNaN(percentile) || percentile <= 0 || percentile > 100)
|
||||
throw new ERR_INVALID_ARG_VALUE.RangeError('percentile', percentile);
|
||||
throw new ERR_OUT_OF_RANGE('percentile', '> 0 && <= 100', percentile);
|
||||
|
||||
return this[kHandle]?.percentile(percentile);
|
||||
}
|
||||
@ -201,9 +199,8 @@ class Histogram {
|
||||
if (!isHistogram(this))
|
||||
throw new ERR_INVALID_THIS('Histogram');
|
||||
validateNumber(percentile, 'percentile');
|
||||
|
||||
if (NumberIsNaN(percentile) || percentile <= 0 || percentile > 100)
|
||||
throw new ERR_INVALID_ARG_VALUE.RangeError('percentile', percentile);
|
||||
throw new ERR_OUT_OF_RANGE('percentile', '> 0 && <= 100', percentile);
|
||||
|
||||
return this[kHandle]?.percentileBigInt(percentile);
|
||||
}
|
||||
@ -283,11 +280,7 @@ class RecordableHistogram extends Histogram {
|
||||
return;
|
||||
}
|
||||
|
||||
if (!NumberIsInteger(val))
|
||||
throw new ERR_INVALID_ARG_TYPE('val', ['integer', 'bigint'], val);
|
||||
|
||||
if (val < 1 || val > NumberMAX_SAFE_INTEGER)
|
||||
throw new ERR_OUT_OF_RANGE('val', 'a safe integer greater than 0', val);
|
||||
validateInteger(val, 'val', 1);
|
||||
|
||||
this[kHandle]?.record(val);
|
||||
}
|
||||
|
@ -91,7 +91,7 @@ const { sleep } = require('internal/util');
|
||||
() => histogram.percentile(i),
|
||||
{
|
||||
name: 'RangeError',
|
||||
code: 'ERR_INVALID_ARG_VALUE'
|
||||
code: 'ERR_OUT_OF_RANGE'
|
||||
}
|
||||
);
|
||||
});
|
||||
|
Loading…
x
Reference in New Issue
Block a user