From 9559d6e45988788abb06282125b8fd276d588651 Mon Sep 17 00:00:00 2001 From: Arian Faurtosh Date: Mon, 9 Feb 2015 10:15:13 -0800 Subject: [PATCH 1/2] Fixed bug in _.sortedIndex that would put undefined at the start (FIXES: #1834) --- test/arrays.js | 27 +++++++++++++++++++++++++++ underscore.js | 3 ++- 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/test/arrays.js b/test/arrays.js index de8ac607d..9f0bbcdf4 100644 --- a/test/arrays.js +++ b/test/arrays.js @@ -137,6 +137,33 @@ equal(_.sortedIndex(array, 2147483648), 2147483648, 'should work with large indexes'); }); + test('sortedIndex conforms to sortBy for undefined (#1834)', function() { + var sorted = _.sortBy([undefined, 1, undefined, 2]); + equal(_.sortedIndex(sorted, undefined, _.identity), 2); + + var edgeCaseNumbers = [-Infinity, -Infinity, 0, Number.MAX_VALUE, Infinity, Infinity, undefined, undefined, NaN]; + + var indexForUndefined = _.sortedIndex(edgeCaseNumbers, undefined); + equal(indexForUndefined, 6, 'undefined should be inserted at index 6'); + + var indexForNegInfinity = _.sortedIndex(edgeCaseNumbers, -Infinity); + equal(indexForNegInfinity, 0, 'negative infinity should be inserted at index 0'); + + var indexForInfinity = _.sortedIndex(edgeCaseNumbers, Infinity); + equal(indexForInfinity, 4, 'infinity should be inserted at index 4'); + + var indexForZero = _.sortedIndex(edgeCaseNumbers, 0); + equal(indexForZero, 2, '0 should be inserted at index 2'); + + var indexForNaN = _.sortedIndex(edgeCaseNumbers, NaN); + equal(indexForNaN, 8, 'NaN should be inserted at index 8'); + + var numbers = [10, 20, 30, 40, 50]; + + var indexForUndefinedSimple = _.sortedIndex(numbers, undefined); + equal(indexForUndefinedSimple, 5, 'undefined should be inserted at index 5'); + }); + test('uniq', function() { var list = [1, 2, 1, 3, 1, 4]; deepEqual(_.uniq(list), [1, 2, 3, 4], 'can find the unique values of an unsorted array'); diff --git a/underscore.js b/underscore.js index d49fd9bc5..e329bd344 100644 --- a/underscore.js +++ b/underscore.js @@ -685,7 +685,8 @@ var low = 0, high = array.length; while (low < high) { var mid = Math.floor((low + high) / 2); - if (iteratee(array[mid]) < value) low = mid + 1; else high = mid; + var cur = iteratee(array[mid]); + if ( cur < value || (value === void 0 && cur <= Infinity) || (_.isNaN(value) && (cur <= Infinity || cur === void 0))) low = mid + 1; else high = mid; } return low; }; From 80942ef0e3b9914b59b4f6e4b1513d2cce8e7851 Mon Sep 17 00:00:00 2001 From: Arian Faurtosh Date: Mon, 9 Feb 2015 11:39:27 -0800 Subject: [PATCH 2/2] updated Number.MAX_VALUE to be a really big number --- test/arrays.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/arrays.js b/test/arrays.js index 9f0bbcdf4..d945fa927 100644 --- a/test/arrays.js +++ b/test/arrays.js @@ -141,7 +141,7 @@ var sorted = _.sortBy([undefined, 1, undefined, 2]); equal(_.sortedIndex(sorted, undefined, _.identity), 2); - var edgeCaseNumbers = [-Infinity, -Infinity, 0, Number.MAX_VALUE, Infinity, Infinity, undefined, undefined, NaN]; + var edgeCaseNumbers = [-Infinity, -Infinity, 0, 345345345234, Infinity, Infinity, undefined, undefined, NaN]; var indexForUndefined = _.sortedIndex(edgeCaseNumbers, undefined); equal(indexForUndefined, 6, 'undefined should be inserted at index 6');