mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-25 15:15:19 +00:00
fix(nuxt): find parent routes by exact path match (#23040)
This commit is contained in:
parent
411ecabd10
commit
40601ec15f
@ -80,7 +80,8 @@ export async function generateRoutesFromFiles (files: string[], pagesDir: string
|
||||
route.name += (route.name && '/') + segmentName
|
||||
|
||||
// ex: parent.vue + parent/child.vue
|
||||
const child = parent.find(parentRoute => parentRoute.name === route.name && !parentRoute.path.endsWith('(.*)*'))
|
||||
const path = route.path + getRoutePath(tokens).replace(/\/index$/, '/')
|
||||
const child = parent.find(parentRoute => parentRoute.name === route.name && parentRoute.path === path)
|
||||
|
||||
if (child && child.children) {
|
||||
parent = child.children
|
||||
|
@ -351,6 +351,91 @@ describe('pages:generateRoutesFromFiles', () => {
|
||||
children: []
|
||||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
description: 'should not merge required param as a child of optional param',
|
||||
files: [
|
||||
{ path: `${pagesDir}/[[foo]].vue` },
|
||||
{ path: `${pagesDir}/[foo].vue` }
|
||||
],
|
||||
output: [
|
||||
{
|
||||
name: 'foo',
|
||||
path: '/:foo?',
|
||||
file: `${pagesDir}/[[foo]].vue`,
|
||||
children: [
|
||||
]
|
||||
},
|
||||
{
|
||||
name: 'foo',
|
||||
path: '/:foo()',
|
||||
file: `${pagesDir}/[foo].vue`,
|
||||
children: []
|
||||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
description: 'should correctly merge nested routes',
|
||||
files: [
|
||||
{ path: `${pagesDir}/param.vue` },
|
||||
{ path: `${pagesDir}/param/index.vue` },
|
||||
{ path: `${pagesDir}/param/index/index.vue` },
|
||||
{ path: `${pagesDir}/param/index/sibling.vue` },
|
||||
{ path: `${pagesDir}/wrapper-expose/other.vue` },
|
||||
{ path: `${pagesDir}/wrapper-expose/other/index.vue` },
|
||||
{ path: `${pagesDir}/wrapper-expose/other/sibling.vue` },
|
||||
{ path: `${pagesDir}/param/sibling.vue` }
|
||||
],
|
||||
output: [
|
||||
{
|
||||
children: [
|
||||
{
|
||||
children: [
|
||||
{
|
||||
children: [],
|
||||
file: 'pages/param/index/index.vue',
|
||||
name: 'param-index',
|
||||
path: ''
|
||||
},
|
||||
{
|
||||
children: [],
|
||||
file: 'pages/param/index/sibling.vue',
|
||||
name: 'param-index-sibling',
|
||||
path: 'sibling'
|
||||
}
|
||||
],
|
||||
file: 'pages/param/index.vue',
|
||||
path: ''
|
||||
},
|
||||
{
|
||||
children: [],
|
||||
file: 'pages/param/sibling.vue',
|
||||
name: 'param-sibling',
|
||||
path: 'sibling'
|
||||
}
|
||||
],
|
||||
file: 'pages/param.vue',
|
||||
path: '/param'
|
||||
},
|
||||
{
|
||||
children: [
|
||||
{
|
||||
children: [],
|
||||
file: 'pages/wrapper-expose/other/index.vue',
|
||||
name: 'wrapper-expose-other',
|
||||
path: ''
|
||||
},
|
||||
{
|
||||
children: [],
|
||||
file: 'pages/wrapper-expose/other/sibling.vue',
|
||||
name: 'wrapper-expose-other-sibling',
|
||||
path: 'sibling'
|
||||
}
|
||||
],
|
||||
file: 'pages/wrapper-expose/other.vue',
|
||||
path: '/wrapper-expose/other'
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
|
||||
@ -360,12 +445,15 @@ describe('pages:generateRoutesFromFiles', () => {
|
||||
test.files.map(file => [file.path, 'template' in file ? file.template : ''])
|
||||
) as Record<string, string>
|
||||
|
||||
let result
|
||||
try {
|
||||
const result = await generateRoutesFromFiles(test.files.map(file => file.path), pagesDir, true, vfs)
|
||||
expect(result).to.deep.equal(test.output)
|
||||
result = await generateRoutesFromFiles(test.files.map(file => file.path), pagesDir, true, vfs)
|
||||
} catch (error: any) {
|
||||
expect(error.message).toEqual(test.error)
|
||||
}
|
||||
if (result) {
|
||||
expect(result).toEqual(test.output)
|
||||
}
|
||||
})
|
||||
}
|
||||
})
|
||||
|
Loading…
Reference in New Issue
Block a user