diff --git a/__tests__/basePath.unit.js b/__tests__/basePath.unit.js index 5e8fc5e..7df7e4e 100644 --- a/__tests__/basePath.unit.js +++ b/__tests__/basePath.unit.js @@ -17,9 +17,21 @@ let event = { } } +api.use(function (req, res, next) { + console.log('HELLO FROM MIDDLEWARE') + req.testMiddleware = "123"; + next(); +}); + /******************************************************************************/ /*** DEFINE TEST ROUTES ***/ /******************************************************************************/ +api.get("/", function(req, res) { + res.status(200).json({ + testMiddleware: req.testMiddleware, + }) +}); + api.get('/test', function(req,res) { res.status(200).json({ method: 'get', status: 'ok' }) }) @@ -40,6 +52,12 @@ api.get('/test/test2/test3', function(req,res) { describe('Base Path Tests:', function() { + it('should return testMiddleware: 123 when calling the root path', async function() { + let _event = Object.assign({},event,{ path: '/v1' }) + let result = await new Promise(r => api.run(_event,{},(e,res) => { r(res) })) + expect(result).toEqual({ multiValueHeaders: { 'content-type': ['application/json'] }, statusCode: 200, body: '{"method":"get","status":"ok"}', isBase64Encoded: false }) + }) + it('Simple path with base: /v1/test', async function() { let _event = Object.assign({},event,{ path: '/v1/test' }) let result = await new Promise(r => api.run(_event,{},(e,res) => { r(res) })) diff --git a/index.js b/index.js index e3f0c4a..ffe9992 100644 --- a/index.js +++ b/index.js @@ -143,6 +143,7 @@ class API { // Make a local copy of routes let routes = this._routes; + // console.log('routes', JSON.stringify(routes)); // Create a local stack for inheritance let _stack = { '*': [], m: [] }; @@ -471,6 +472,7 @@ class API { this.METHOD('__MW__', route, ...middleware); }); } + } // end use // Finally handler