mirror of
https://github.com/kremalicious/astro-redirect-from.git
synced 2025-01-01 09:47:45 +01:00
getRedirects test
This commit is contained in:
parent
cc0ba7d390
commit
23b8f01601
@ -25,9 +25,9 @@ export function getSlugFromFilePath(filePath: string) {
|
||||
// - folder name if file name is index.md, or
|
||||
// - file name
|
||||
if (parsedPath.base === 'index.md' || parsedPath.base === 'index.mdx') {
|
||||
slug = `/${parsedPath.dir}`
|
||||
slug = `${parsedPath.dir}`
|
||||
} else {
|
||||
slug = `/${parsedPath.dir}/${parsedPath.name}`
|
||||
slug = `${parsedPath.dir}/${parsedPath.name}`
|
||||
}
|
||||
|
||||
return slug
|
||||
|
6
test/__fixtures__/markdown/hello-astro.md
Normal file
6
test/__fixtures__/markdown/hello-astro.md
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
slug: hello-astroooooo
|
||||
redirect_from:
|
||||
- /hello-astro-old
|
||||
- hello-astro-old-234837
|
||||
---
|
6
test/__fixtures__/markdown/hello-draft.md
Normal file
6
test/__fixtures__/markdown/hello-draft.md
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
draft: true
|
||||
|
||||
redirect_from:
|
||||
- /hello-draft-old
|
||||
---
|
27
test/getRedirects.test.ts
Normal file
27
test/getRedirects.test.ts
Normal file
@ -0,0 +1,27 @@
|
||||
import { expect, it, describe } from 'vitest'
|
||||
import { getRedirects } from '../src/getRedirects'
|
||||
import { getMarkdownFiles, getSlugFromFilePath } from '../src/utils'
|
||||
|
||||
describe('getRedirects', async () => {
|
||||
// handling this more as an integration test
|
||||
const srcDir = './test/__fixtures__/markdown'
|
||||
const files = await getMarkdownFiles(srcDir)
|
||||
|
||||
it('should return redirects', async () => {
|
||||
const result = await getRedirects(
|
||||
files,
|
||||
srcDir,
|
||||
getSlugFromFilePath,
|
||||
'build'
|
||||
)
|
||||
expect(result).toBeInstanceOf(Object)
|
||||
expect(result).toStrictEqual({
|
||||
'/hello-astro-old': '/hello-astroooooo',
|
||||
'/hello-astro-old-234837': '/hello-astroooooo',
|
||||
'/hello-world-old': '/hello-world',
|
||||
'/hello-world-old-234837': '/hello-world',
|
||||
'/hello-markdown-old': '/hello-markdown',
|
||||
'/hello-markdown-old-234837': '/hello-markdown'
|
||||
})
|
||||
})
|
||||
})
|
@ -11,7 +11,7 @@ describe('getMarkdownFiles', () => {
|
||||
it('should return an array of markdown files from the given directory', async () => {
|
||||
const files = await getMarkdownFiles('./test/__fixtures__/markdown')
|
||||
expect(files).toBeInstanceOf(Array)
|
||||
expect(files).toHaveLength(2)
|
||||
expect(files).toHaveLength(4)
|
||||
})
|
||||
})
|
||||
|
||||
@ -28,17 +28,17 @@ describe('getMarkdownFrontmatter', () => {
|
||||
describe('getSlugFromFilePath', () => {
|
||||
it('should return slug for testDir/testFile.md', () => {
|
||||
const slug = getSlugFromFilePath('testDir/testFile.md')
|
||||
expect(slug).toBe('/testDir/testFile')
|
||||
expect(slug).toBe('testDir/testFile')
|
||||
})
|
||||
|
||||
it('should return slug for dir/testDir/index.md', () => {
|
||||
const slug = getSlugFromFilePath('dir/testDir/index.md')
|
||||
expect(slug).toBe('/dir/testDir')
|
||||
expect(slug).toBe('dir/testDir')
|
||||
})
|
||||
|
||||
it('should return slug for dir/dir2/testDir/index.md', () => {
|
||||
const slug = getSlugFromFilePath('dir/dir2/testDir/index.md')
|
||||
expect(slug).toBe('/dir/dir2/testDir')
|
||||
expect(slug).toBe('dir/dir2/testDir')
|
||||
})
|
||||
})
|
||||
|
||||
@ -49,7 +49,7 @@ describe('writeJson', () => {
|
||||
try {
|
||||
await fs.unlink(testFilePath)
|
||||
} catch (error) {
|
||||
console.error('Error cleaning up test file:', error)
|
||||
return
|
||||
}
|
||||
})
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user