From ddeb097a7f29b8fcdd7b4082fa4f8b55e5e386a9 Mon Sep 17 00:00:00 2001 From: Bob Evans Date: Wed, 18 Sep 2024 16:51:01 -0400 Subject: [PATCH] test: Updated how we handle the koa-router nuance of wildcard routes (#2588) --- test/versioned/koa/package.json | 4 ++- test/versioned/koa/router-common.js | 41 ++++++++++++++++++++++------- 2 files changed, 34 insertions(+), 11 deletions(-) diff --git a/test/versioned/koa/package.json b/test/versioned/koa/package.json index 50a1775d0f..070e8e87aa 100644 --- a/test/versioned/koa/package.json +++ b/test/versioned/koa/package.json @@ -81,5 +81,7 @@ ] } ], - "dependencies": {} + "engines": { + "node": ">=18" + } } diff --git a/test/versioned/koa/router-common.js b/test/versioned/koa/router-common.js index 3bc0d98159..9c2ef19f98 100644 --- a/test/versioned/koa/router-common.js +++ b/test/versioned/koa/router-common.js @@ -4,6 +4,27 @@ */ 'use strict' +const fs = require('fs') + +/** + * koa-router and @koa/router updated how they defined wildcard routing + * It used to be native and then relied on `path-to-regexp`. If `path-to-regexp` + * is present get the version. For post 8 it relies on different syntax to define + * routes. If it is not present assume the pre 8 behavior of `path-to-regexp` + * is the same. Also cannot use require because `path-to-regexp` defines exports + * and package.json is not a defined export. + */ +function getPathToRegexpVersion() { + let pathToRegexVersion + try { + ;({ version: pathToRegexVersion } = JSON.parse( + fs.readFileSync(`${__dirname}/node_modules/path-to-regexp/package.json`) + )) + } catch { + pathToRegexVersion = '6.0.0' + } + return pathToRegexVersion +} module.exports = (pkg) => { const tap = require('tap') @@ -15,6 +36,7 @@ module.exports = (pkg) => { tap.test(`${pkg} instrumentation`, (t) => { const { version: pkgVersion } = require(`${pkg}/package.json`) const paramMiddlewareName = 'Nodejs/Middleware/Koa/middleware//:first' + const pathToRegexVersion = getPathToRegexpVersion() /** * Helper to decide how to name nested route segments @@ -149,7 +171,7 @@ module.exports = (pkg) => { t.test('should name and produce segments for matched wildcard path', (t) => { const { agent, router, app } = t.context let path = '(.*)' - if (pkg === 'koa-router' && semver.gte(pkgVersion, '13.0.1')) { + if (semver.gte(pathToRegexVersion, '8.0.0')) { path = '{*any}' } router.get(`/:first/${path}`, function firstMiddleware(ctx) { @@ -347,16 +369,15 @@ module.exports = (pkg) => { ctx.body = ' second' }) - const segmentTree = - pkg === 'koa-router' && semver.gte(pkgVersion, '13.0.1') - ? ['Nodejs/Middleware/Koa/terminalMiddleware//:second'] - : [ - 'Nodejs/Middleware/Koa/secondMiddleware//:first', - [ - 'Nodejs/Middleware/Koa/secondMiddleware//:second', - ['Nodejs/Middleware/Koa/terminalMiddleware//:second'] - ] + const segmentTree = semver.gte(pathToRegexVersion, '8.0.0') + ? ['Nodejs/Middleware/Koa/terminalMiddleware//:second'] + : [ + 'Nodejs/Middleware/Koa/secondMiddleware//:first', + [ + 'Nodejs/Middleware/Koa/secondMiddleware//:second', + ['Nodejs/Middleware/Koa/terminalMiddleware//:second'] ] + ] app.use(router.routes()) agent.on('transactionFinished', (tx) => { t.assertSegments(tx.trace.root, [