From 5d7a467909cefd3c46e488904b74dc75a3adc1ae Mon Sep 17 00:00:00 2001 From: Stephen Hess Date: Tue, 16 May 2017 15:14:26 -0400 Subject: [PATCH] added response data sorting middleware --- middleware/sortResponseData.js | 2 +- test/unit/middleware/sortResponseData.js | 74 +++++++++++++++++++++++- 2 files changed, 73 insertions(+), 3 deletions(-) diff --git a/middleware/sortResponseData.js b/middleware/sortResponseData.js index 78bb1808..d146df60 100644 --- a/middleware/sortResponseData.js +++ b/middleware/sortResponseData.js @@ -7,7 +7,7 @@ function setup(comparator) { return next(); } - res.data = res.data.sort(comparator); + res.data = res.data.sort(comparator(_.get(req, 'clean', {}))); next(); } diff --git a/test/unit/middleware/sortResponseData.js b/test/unit/middleware/sortResponseData.js index 3eabfae7..1cb64526 100644 --- a/test/unit/middleware/sortResponseData.js +++ b/test/unit/middleware/sortResponseData.js @@ -3,6 +3,74 @@ const sortResponseData = require('../../../middleware/sortResponseData'); module.exports.tests = {}; module.exports.tests.doIt = (test, common) => { + test('{} should be passed to comparator when req is unavailable', (t) => { + const comparator = (clean) => { + t.deepEquals(clean, { }); + return () => { + throw Error('should not have been called'); + }; + }; + + const sort = sortResponseData(comparator); + + const res = { + data: [ {} ] + }; + + sort(undefined, res, () => { + t.end(); + }); + + }); + + test('{} should be passed to comparator when req.clean is unavailable', (t) => { + const comparator = (clean) => { + t.deepEquals(clean, { }); + return () => { + throw Error('should not have been called'); + }; + }; + + const sort = sortResponseData(comparator); + + const req = {}; + + const res = { + data: [ {} ] + }; + + sort(req, res, () => { + t.end(); + }); + + }); + + test('req.clean should be passed to sort', (t) => { + const comparator = (clean) => { + t.deepEquals(clean, { a: 1 }); + return () => { + throw Error('should not have been called'); + }; + }; + + const sort = sortResponseData(comparator); + + const req = { + clean: { + a: 1 + } + }; + + const res = { + data: [ {} ] + }; + + sort(req, res, () => { + t.end(); + }); + + }); + test('undefined res should return without interacting with comparator', (t) => { const comparator = () => { throw Error('should not have been called'); @@ -51,8 +119,10 @@ module.exports.tests.doIt = (test, common) => { }); test('comparator should be consulted for sorting res.data when defined', (t) => { - const comparator = (a, b) => { - return a.key > b.key; + const comparator = () => { + return (a, b) => { + return a.key > b.key; + }; }; const sort = sortResponseData(comparator);