From 0265a804acad26f3a58fbdf3635c8888b2ad10c8 Mon Sep 17 00:00:00 2001 From: Wes Todd Date: Tue, 27 Feb 2024 17:22:50 -0600 Subject: [PATCH 1/2] fix: support express@5 router --- lib/generate-doc.js | 13 ++++++++++++- package.json | 4 +++- test/index.js | 11 ++++++++++- 3 files changed, 25 insertions(+), 3 deletions(-) diff --git a/lib/generate-doc.js b/lib/generate-doc.js index 03168d0..803f132 100644 --- a/lib/generate-doc.js +++ b/lib/generate-doc.js @@ -69,7 +69,6 @@ module.exports = function generateDocument (baseDocument, router, basePath) { function iterateStack (path, routeLayer, layer, cb) { cb(path, routeLayer, layer) - if (layer.name === 'router') { layer.handle.stack.forEach(l => { path = path || '' @@ -113,6 +112,16 @@ function processComplexMatch (thing, keys) { // https://github.com/expressjs/express/issues/3308#issuecomment-300957572 function split (thing, keys) { + // In express v5 the router layers regexp (path-to-regexp@3.2.0) + // has some additional handling for end of lines, remove those + // + // layer.regexp + // v4 ^\\/sub-route\\/?(?=\\/|$) + // v5 ^\\/sub-route(?:\\/(?=$))?(?=\\/|$) + // + // l.regexp + // v4 ^\\/endpoint\\/?$ + // v5 ^\\/endpoint(?:\\/)?$ if (typeof thing === 'string') { return thing.split('/') } else if (thing.fast_slash) { @@ -122,6 +131,8 @@ function split (thing, keys) { .toString() .replace('\\/?', '') .replace('(?=\\/|$)', '$') + // Added this line to catch the express v5 case after the v4 part is stripped off + .replace('(?:\\/(?=$))?$', '$') .match(/^\/\^((?:\\[.*+?^${}()|[\]\\/]|[^.*+?^${}()|[\]\\/])*)\$\//) return match ? match[1].replace(/\\(.)/g, '$1').split('/') diff --git a/package.json b/package.json index 1fa444b..ad668c8 100644 --- a/package.json +++ b/package.json @@ -17,11 +17,13 @@ }, "scripts": { "test": "standard && mocha", - "prepublishOnly": "npm t", + "prepublishOnly": "EXPRESS_MAJOR=4 mocha && EXPRESS_MAJOR=5 mocha", "postpublish": "git push origin && git push origin --tags" }, "devDependencies": { "express": "^4.18.2", + "express4": "github:expressjs/express#4.18.3-staging", + "express5": "npm:express@^5.0.0-beta.1", "mocha": "^10.2.0", "standard": "^17.1.0", "supertest": "^6.3.3" diff --git a/test/index.js b/test/index.js index dbe5bc3..77122ef 100644 --- a/test/index.js +++ b/test/index.js @@ -3,12 +3,21 @@ const { suite, test } = require('mocha') const assert = require('assert') const util = require('util') const supertest = require('supertest') -const express = require('express') const SwaggerParser = require('swagger-parser') const openapi = require('../') const { name } = require('../package.json') const YAML = require('yaml') +// We support testing with different major versions of express +let spec = 'express' +if (process.env.EXPRESS_MAJOR) { + if (!['4', '5'].includes(process.env.EXPRESS_MAJOR)) { + throw new Error('EXPRESS_MAJOR contained an invalid value') + } + spec += process.env.EXPRESS_MAJOR +} +const express = require(spec) + function logDocument (doc) { console.log(util.inspect(doc, { depth: null })) } From 862611c16aec9d39d6e869a559c1e60f104acac7 Mon Sep 17 00:00:00 2001 From: Wes Todd Date: Tue, 27 Feb 2024 17:41:36 -0600 Subject: [PATCH 2/2] fix!:drop node 14 from test --- .github/workflows/test.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index db1fd2b..a12d36a 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -5,7 +5,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - node-version: [14.x, 16.x, 18.x, 20.x] + node-version: [16.x, 18.x, 20.x] steps: - uses: actions/checkout@v3 - name: Use Node.js ${{ matrix.node-version }}